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PREFACE 


The notion of a microprogram was first presented in 1951- 
-which may seem extraordinary since the vacuum tube and 
the relay were then the only switching devices available. 
This was only eight years after the first electronic computer 
had been introduced. Microprogramming was used infre- 
quently until the mid-1960s, by which time several 
computing systems had appeared in the industry that 
relied on microprogramming in their contro! unit design. 
Microprogramming then became, and remains, an enor- 
mously beneficial and popular methodology in the comput- 
ing world. 


The reader of this guide should have some knowledge of 
the hardware components of a computer system, such as 
the functions and uses of registers, schemes of handling 
interrupts etc. Programming techniques which make 
efficient assembly-language functions like indexing and 
high-speed algorithms will be useful here too. When a 
microprogram is executed thousands of times more often 
than any one application program, its fine tuning is also 
needed that many more times. Also the microprogrammer 
should know the problem-oriented languages used. To 
choose which operators to microprogram, the designer 
must be aware of the eventual applications. Combining 
operators which are often used in the same sequence could 
form a single microprogrammed operator with a greater 
overlapping of actions. 


In studying a component of a computing system it is often 
true that at first glance the given component seems to 
introduce much complexity even though, presumably, the 
component also seems to introduce greater ease of 
operation and greater efficiency. Though microprogram- 
ming adds more complexity, the result is to make a system 
easier to use. One goal of this guide is to bring micropro- 
gramming into the range of a good programmer. To that 
end the guide is written in simple language (with a glossary 
to look up any unfamiliar terms) and there is a gradual 
progression from the big picture to the details through 
numerous examples. 


This guide is both a tutorial and a reference. If micropro- 
gramming is new to you, start at the beginning of this 
guide and use it as a tutorial. Later the book can be used 
for reference. The charts and examples are built up in a 
logical development so that the complete examples will be a 
pattern for your programming. 


Sperry Univac does not assume responsibility for micro- 
programs written and implemented according to the 
recommendations outlined herein. 
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SECTION 1 
INTRODUCTION 


The control function for a digital system can be expressed 
very much as a program. Microprogramming is character- 
ized as a methodology whereby such a program is stored in 
memory and read out, step-by-step, in program sequence. 
Each time a ''step"” is read, there is either a branch within 
the program or a register transfer within the computer. The 
control unit of a microprogrammable computer consists 
chiefly of a memory rather than a large network of control 
delays. The instructions stored in memory are called 
microinstructions. See figure 1-1 for a simplified distinction 
between the hardware configurations of a microprogram- 
med and a conventional computer. 


1.1 ADVANTAGES 


The random logic of a conventional computer can be 
replaced with a more structured organization. A conven- 
tional computer system uses a collection of counters, 
special flip-flops, decoding networks and other components 
unique to a particular purpose for control logic. In contrast, 
a microprogram memory replaces most of this. The 
microprogram storage is formed of regular and repetitive 
units. There are fewer components, thus increasing the 
reliability of the system. 


The flexibility of the instructions in the control store offers 
the ability to change the system in ways so basic that they 
are not at all feasible in a fixed instruction set. Field 
changes can be made by merely changing the controlling 
microprograms. Final systems definition can be postponed 
until a later stage of the design. Performance can be 
economically expanded at a lower cost. 


Emulation of a number of diverse devices--not only 
processors but peripheral controllers, for instance--can be 
carried out on a single microprazrammed system. Simulta- 
neous emulation of some devices can be made or the target 
system can be changed depending upon needs. This can 
save reprogramming and retraining resources and yet gain 
the speed and reliability of a more advanced system. Also 
the documentation and minor logistic problems of a new 
machine can be avoided. 


For more reliability and the continuous perforr:ance 
necessary in many uses of computers, diagnostics and 
servicing aids may be implemented in the control store. To 
pinpoint problems the microprocessor can both test and 


set states not available to the assembly-language program. 
mer on a conventional machine. 


Standard 
Software 
Coding 
Execution MICRO- 
Time PROGRAMS 
Special 
Purpose 
Hardware 


Cost 


Instructions Tailored To Particular Environments 


in general, microprogrammed instructions permit more 
compact program representation. They use less main 
memory than the equivalent would in conventional code. 
Consequently, fewer memory fetches for anything other 
than data are needed. 


As an example of a possible microprogrammed operator 
which reduces memory fetches, consider a common use of 
arrays. Higher-level programming languages, such as 
FORTRAN, BASIC, COBOL -- in fact, nearly all-- have 
facilities for expressing a repetitive linear data structure, a 
list or array. Arrays are an integral part of a large class of 
techniques for diverse problems. Yet good operators for 
arrays as such are not available as simple, single 
instructions in a conventional! machine. 


In usual machine code the function of adding two 
numerical arrays of the same size and number of elements 
usually requires a series of actions as follows for each pair 
of elements: 

a. load memory to register 

b. add memory to register 

c. store register result in memory 

d. update indices and close !aop 
The first two steps would each require a memory fetch and 


the last step as many as three memory fetches. 


A microprogrammed instruction would provide initializing 
data descriptors and repetitively executing micro-operators 
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over the described arrays of data. To start the program 
segment would require several steps: 


a. load the starting address, increment and extent of each 
array 


b. load the resuit's starting address, increment and 
extent 


c. define the end and branch condition 


This initialization could be followed by one instruction to 
execute the newly-defined operator equivalent to the series 
of typical instructions. 


An extension of this principle of reducing m::niory retrieval 
of instructions occurs in some spectal cases where data 
normally resident in the stream of instructions can be 
removed and instead reside in special-purpose micro- 
routines. For example, if the array addition algorithm above 
were limited to fixed-length arrays with fixed-size elements, 
the increment and extent parameters could be stored as 
local constants in the microprogram, eliminating the need 
to transfer this information in the initial sequence. 


1.2 GUIDE TO THIS MANUAL = 


The purpose of this section is to provide the user with a 
heipful idea of the structure of the remainder of the 
manual. The order of the following sections is based on the 
order in which a programmer needs the information to 
plan, then code, test and run microprograms. 


Information in the sections 


Introduction (Section 1) 
Advantages of microprogramming 
Guide to the remainder of the manual 
Conventions (defining some words and notation) in the 
manual 
Components of microprogrammed systems 


Capabilities (Section 2) 
Micro operations available in central control store 
Building blocks of microprograms providing data 
transfer and transformations, conditional tests, and 
memory access 


Techniques (Section 3) 
Explanation of interface with the 620 emulation 
Procedures to use flow diagrams to write 
microprograms 
Examples of microprograms 


Microprogram Assembler (Section 4) 
Directives to code microprograms 
Macros 
Operating instructions 


Coding from Flow Diagrams (Section 5) 
Conversion steps and tables 
Examples from section 3 


Microprogram Simulator (Section 6) 
Directives 
Operating instructions 


Microprogram Utility (Section 7) 
Directives 
Operating instructions 


Decoder: control store, !1/O control and additional topics 
(section 8) 

Format and use of optional decoder control store 

1/0 microprogramming procedures and example 


Glossary (Section 9) 
Terminology for microprogramming defined 
Mnemonics defined 


1.3 NOTATION IN THIS MANUAL 


References to Microinstruction Fields 


Within the microinstruction the fields are named with the 
two-letter references recognized by the micro-assembler. 
Some of the fields have names which are used in the text, 
such as the CF field conveniently called the carry field. 


References Within Fields 


The bits within the fields are often discussed one at a time. 
Several techniques are used to single out bits. A field may 
be represented with the letter X in bit positions not 
involved in the action being discussed. 1X for a two-bit 
field indicates that only the high-order bit is required to be 
one in this action, i.e., setting the field to 10 or 11. High- 
order and leftmost are synonymous to select a particular 
bit or group of bits. Similarly low-order and rightmost 
select the same bit or a contiguous set of bits. Finally less 
often a bit is mentioned by number with the convention 
that bits are numbered from right to left starting with 
zero. 


Syntax of Directives 


In the directive formats for the microprogramming software 
the syntax is given with the following conventions: 


Boldface type indicates a required parameter 
Italic type indicates an optional parameter 


Upper-case type indicates that the item is to be 
entered exactly as written 


Lower-case type indicates a variable and shows 
where the user enters a value for that variable. 


The formation of a list of the same items is indicated by 
three consecutive periods. 


For example, the syntax for the MIDAS FORM statement is 
as follows , 


label FORM field(1), field(2),..., field(n) 
Where: 
label is a symbol as defined in MIDAS 
basic elements 
each field iS a field identifier which is the 
field length in decimal, followed 
by an optional hexadecimal constant 
enclosed in parentheses 
Numbers 


Microinstruction fields are giver in binary notation unless 
indicated otherwise in the context of the reference. 


Definitions 


To remove one barrier that often exists to the understand. 
ing of microprogramming this section clarifies some terms 
we use. 


In a computer system many different kinds of storage exist 
for data, instructions or both. Microprograms reside in the 
system's contro! store. All control store must be writable in 
some manner so that the control information can be 
introduced. The desire for greater speed often leads to the 
design of storage that can only be loaded once and even 
then only by mechanical or electromechanical means. 
These are designated as read only or ROM for read-only 
memory. This differentiates them from the arrays whose 
contents can be changed by the user. This is called 
writable control store (WCS). 


The microprogram is a series of microinstructions. A 
microinstruction resides in one fixed-length word in control 
store. The microword§ is 64 bits long and selects the 
operations which occur in one machine cycle (with some 
exceptions). The individual operations, micro-operations or 
primitives, are defined by fields within the microword. 


In this manual whenever you encounter unfamilar words 


look for the definition at the first use of the word or 
consult the glossary in section 9. 


1.4 COMPONENTS 


1.4.1 Hardware for Microprogrammed Systems 


Though the software for microprogramming provides an 
interface for the user to program the system, to plan a 
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good system one needs to be very aware of the actual 
functions of the hardware. The tangible parts of the 
microprogramming system are described below. 


Processor 


The major functional componentsof theSPERRY UNIVAC 
V70 series processor (figure 1-2) are central control, data 
loop, memory control, I/O data loop, and l/O control. The 
processor communicates with the computer control 
panel via the I/O bus. 


The processor speed is 165 nanoseconds for a 
microinstruction. 


Central Control 


Central control provides supervision for most of the major 
components in the processor. Direct control is exercised 
over the data loop. Requests may be made to other 
components, such as memory and |/O control. 


The key element in central contro! is a 64-bit control buffer. 
This buffer, which is simply a microinstruction, completely 
describes a set of actions for the other processor 
components. For example, the data loop might be 
instructed to increment one of the general-purpose regis- 
ters. The memory control might be requested to begin the 
fetch of a 16-bit word from main memory. Thus, the 
control buffer holds the current microinstructions. It is 
somewhat analogous to the instruction register in 
assembly-language programming. 


The 64 bits also specify the location of the new contents 
for the control buffer. The control buffer is always loaded 
from 64-bit central control store. Thus, execution of a 
microprogram basically consists of the control buffer 
being sequentially loaded with the appropriate 64-bit 
values. Central control store in a V70 series system is 
divided into pages, each consisting of 512 64-bit words. 
Page zero of central contro! store always contains a set of 
microinstructions which direct the processor com- 
ponents to behave like a 620/f. This set of 512 micro- 
words is thus called the 620/f emulation, and resides in 
read-only memory (ROM). Other central contro! store 
pages may be added with the writable control store 
(WCS) option, thus allowing the user to specify in detail 
the actions of the processor components. 


The microprograms for the standard instruction set are 
described in the microinstruction flowcharts in the 
System Maintenance Manual and in assembly language 
in an appendix to this guide. 


Data Loop 


The data loop provides transfer paths, data transformation 
circuits, storage registers and counters (figure 1-3). 


Under control of the central! contro! buffer the arithmetic 
and logic unit (ALU) performs basic arithmetic functions 
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such as addition, subtraction, and the common logical 
functions including AND and OR. ALU output can be 
directed to a number of places, including registers and 
counters in the data loop, registers in the |/O data loop, 
and to memory control. 


Memory Control 


The memory control section of the processor performs 
tasks istiated by the central control, 1/O control and 
options. These tasks consist of reading a 16-bit word from 
memory or writing a word or byte into memory. 


Memory control acknowledges receipt of the signal to the 
requesting sections and signals when done with the task. 
When one request is accepted no others are acknowl. 
edged until the current one is completed, but central 
control can override its own prior request. 


1/O Data Loop 


The [/O data loop contains a multiplexor, 1/O data register, 
and drivers and receivers. Three sources of data are 
applied to the |/O data loop: data from the 1/0 bus, data 
from the arithmetic and logic unit, and data from the 
memory |/O register (MIOR). The input data is selected by 
the !/O multiplexor under control of the I/O contro! signals 
and transferred on to the bidirectional !/O bus. 


in addition to being applied to the !/O drivers, the output 
of the 1/O data register is applied to the data loop and 
memory control sections. 


1/0 Control 


The 1/0 control operates under control of an independent 
read-only memory (ROM). It performs !/O operations 
initiated either by the central control or 1/O device activity. 
This permits !/O operations to proceed with minimal 
impact on internal processor functions. The I/O performs 
programmed 1/0 initiated by the central control. Both 
normal and high-speed direct memory access (DMA) are 
handled by the |/O control. 1/O interrupts are processed 
by 1/0 control. 


1.4.2 Writable Control Store 


The Writable Control Store (WCS) extends the processor's 
read-only control store to permit addition of new instruc- 
tions, development of microprogrammed diagnostics, and 
optimal tailoring of the computer system to its applications. 


Unlike the read-only control store which contains the 
V70 series standard instruction set and cannot be 
altered, the WCS can be loaded from the computer's 
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main memory under control of 1/O instructions. This 
Capability of altering the contents of the WCS gives the 
user complete access to the resources of the computer 
system. 


A test program for the WCS hardware is provided to assist 
in maintaining the system. Operating the test program is 
described in the maintenance manual for the WCS. 


Configurations 


The WCS is available in three configurations: 


1. Model 7x-4002 includes a 512-word by 64-bit 
control store, subroutine stack, decoder control 
store, and !/O control store. 


2. Model 7x-4003 includes a 1024 word by 64-bit 
control store and a subroutine stack. 


3. Model 7x-4004 includes a 2048 word by 64-bit 
control store and a subroutine stack. 


Model 7X-4002 is shown in the block diagram of figure 1-4. 
The three control stores shown in this diagram are the 
writable counterparts for read-only components of the 
processor. 


The decoder control store replaces the instruction buffer, 
decoder, and decoding logic in the processor to improve 
instruction set changes. It is formed from two 16-word by 
16-bit memory arrays with the logic that decodes main 
memory instructions into an address for the central 
control store. 


The central control store is a counterpart of the page zero 
of read-only storage. With each processor clock pulse, a 64- 
bit microinstruction is read from the central control store 
to specify the actions to occur. A_ typical microinstruction 
may define several operations such as selecting the next 
control store microinstruction to be executed, test condi- 
tions for branching, initiating memory operations and 
selecting ALU functions. 


The 1/0 contro! store contains a 256-word memory array of 
16-bit words. 


A standard feature with all ‘WCS models is the subroutine 
stack that increases storage efficiency by providing a call 
and return capability for subroutines of microinstructions. 
Up to 16 addresses for branches can be stored in the 
stack. Operations are provided for pushing, popping, and 
deleting an entry. 


The maximum amount of writable control store which 
can be installed in a V70 series computer is 8 pages, or 
4096 words. This amount of WCS is contained on 2 Model 
7X-4004 circuit boards. 
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1.4.3 Software Modules 


Microprogram preparation uses a sequence of software 
provided with the WCS. First the program is written and 
assembled with a special assembler called MIDAS. Upon 
error-free assembly the code is run in a simulated 
environment which is completely independent of a: WCS. 
The ability to trace and correct the execution is available 
with the microsimulator. These first two steps can occur 
without a WCS. Then only when the microprograms are 
checked completely the code can be loaded in the WCS 


with the micro-utility program. In addition to loading the 
utility provides some diagnostics. These steps are depicted 
in figure 1-5. 


All the components of the microprogramming software 
were designed to operate both under operating systems, 
MOS and VORTEX, and as stand-alone programs on the 
SPERRY UNIVAC V70 or 620 series computers. 
Operating systems require a minimum configuration 
(see the manual for the particular operating system). 
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Figure 1-5. Steps for Realizing Microprograms 
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Table 1-1 lists the hardware requirements for micropro- 
gramming software. 


Assembler 


An assembler is a computer program which translates 
symbolic statements into machine instructions. The sym- 
bols are more meaningful than the strings of bit settings 
they represent. In addition to simply translating from 
symbolic to the executable code, the assembler assigns 
storage locations to the assembied instructions and 
produces a form of the instructions for loading into the 
processor's control store. 


The microprogram data assembler (MIDAS) allows the user 
to prepare microprograms for the WCS. Through the use of 
operation mnemonics, symbolic addressing, address-field 
calculation, macro definitions, error detection and auto- 


MIDAS is designed to provide the user with a tool! for 
microprogram implementation. While relieving the user of 
much of the tedious housekeeping associated with 
generating microinstructions and their data fields, it also 
allows the user to describe the microinstructions at their 
most fundamental level. 


INTRODUCTION 


Simulator 


Verifying that the microprogram does indeed solve the 
problem is the next step. A logical step in implementing a 
microprogram is to run it with the microsimulator. The 
effects of executing a faulty microprogram are iikeiy to be 
worse than those caused by poor assembly-language 
coding. 


The simulator runs the output from the assembler within 
main-memory storage. At selected times conditions and the 
contents of data locations can be changed and examined. 
Projected changes can be simulated to evaluate eventual 
changes to the microprograms. 


After determining that the code is error-free the WCS can 
be loaded with the utility program, which uses a command 
set as consistent as possible with the simulator. 


Utility 


Loading the WCS with the assembled and test microcode is 
performed by the microprogram utility, MIUTIL. In addi- 
tion, on-line debugging directives are available through the 
utility. 


Table 1-1. WCS Software Configuration Matrix 


Operating Memory (K) 
Program System 8 12 16 20 24 32 
Micro- VORTEX xX R OO 
Assembler 
MIDAS MOS XR OO 0 
SA XR 0000 
Micro- VORTEX X RO 
Simulator 
MICSIM MOS Xx R OO 
SA xX R O 
Micro- VORTEX x O O 
Utility 
MIUTIL MOS XR OO O 
SA XR O 0 0 
WCS Test XN N N WN 
Program 


> 0° OO oO o 


High- 

TTY TTY TTY Speed 
Keyboard/ PT PT PT 
Printer Reader Punch Reader 

xX N N 0) 

x x N e) 

x X x @) 

xX N N Xx 

X xX N R 

x xX N R 

X N N X 

xX X N R 

x x N R 

R @) N x 

(continued) 
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SECTION 2 
CAPABILITIES 


. 


This section describes micro-operations available with 
SPERRY UNIVAC V70 series systems. The operations 
are grouped into the following categories: 


a. data transfer and transformation 
b. addressing and conditional actions 
c. memory access 

d. other controls 


A basic example follows these sections. Some important 
timing considerations are presented at the conclusion of 
this section of capabilities. 


This section describes only central control store 
programming. 


1/0 and decoder contro! stores are treated in section 8. 


2.1 GENERAL MICROINSTRUCTIONS 


The 64 bits of the microinstruction are grouped into fields 
referenced by either an ordinal number or a two-letter 
name for the microprogram assembler. The full resources 
of the system can be exploited by the user who is familiar 
with all the defined microinstruction fields. To start most 
common operations, a limited set of fields is involved. 


Because some of the bit combinations in the microword 
have no function, the user should be cautious and avoid 
coding those bit settings not defined. Undefined codes may 
be assigned new functions in the future. 
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CAPABILITIES 


2.2 DATA TRANSFER AND 
TRANSFORMATION 


2.2.1 ALU Input Sources 


Input to the arithmetic and logic unit (ALU) is selected by a 
combination of fields. The ALU receives two inputs, A and 
B. Two buses can move information to the ALU but the 
same sources are not available for both buses. Some inputs 
to the ALU can be sent on either bus and some on both. 
The general-purpose registers can be selected as input 
upon either bus and a specific register selected for each 
bus. 


Any of the general-purpose registers can be shifted an its 
way on the A bus to the ALU. Shifting can be one bit 
position to the left or right. 


Input to the ALU can be from one or two of the general- 
purpose registers. The use of one of these registers is 
indicated by setting field LA to zero for input on the A bus, 
and LB for input on the B bus. The specific register is 
specified in AA and/or BB. 


For example to use registers R2 and R4 as the input to the 
ALU 


field LB LA BB AA 
value 0 0 2 4 
(hex.) 

Mnemonic BSGPR A$GPR R2 R4 


LA can also specify that the register indicated by AA is 
shifted or rotated. Shift left and shift right are indicated in 
the LA field and the shift field, SH. 


Special Registers as ALU Input 


By setting the LB field to one, SREG for special register the 
value in the BB field takes on a different meaning: 


OPR Operand register 
MIR Memory input register 
1OR (/O register 


STAT Processor status word 
ORSE Operand right byte sign extended 
OLSE Operand left byte sign extended 
ORZF Operand right byte zero fill 
OLZF Operand right byte in the 

left byte position zero fill 


NOP WN O 
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Table 2-1. ALU Input A Bus Selections 


ALU Input A Bus Source Fields 


Program counter 


General-purpose 
register (any one 
of 16) specified 
in AA 


Neither 
X01 nor 
X1X 


General-purpose 
register (any one 
of 16) specified in 
AA 


All zeros input 


| Ail ones input 

General register (in 

AA) shifted left 

Bit 15 = register 

bit 14 

Bit 15 = register 

bit 15 

Bit 00 = zero 
Bit OO = register 
bit 15 


Bit 00 = operand 
register bit 15 


General register (in 
AA) shifted right 


Bit 15 = multiply 
sign flag 

Bit 15 = register 
bit 00 

Bit 15 = register 
bit 15 

Bit 15 = operand 
register bit 00 
Bit 15 = zero 


X indicates the bit in that position is of no consequence 
to this action. 
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ALU INPUT B 


VTN-1802 
Figure 2-2. General-Purpose Registers, Operand Register and ALU Input 
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Table 2-2. ALU Input B Bus Selections 


ALU Input B Bus Source Fields 


General-purpose Specifies 
register (any one register 
of 16) 


Operand register C000 
full word 

Operand register O100 
right byte with 

sign extended 

Operand register 

left byte with 

sign extended 

Operand register 

right byte with 

zeros in left byte 

Operand register 

right byte in left 

byte position; zeros 

in right 


Memory input register 
(MIR) 


1/O register (JOR) 


Processor status word 
(STAT) 


Instruction register 
masked by 16-bit 

literal constant 
consisting of fields 

MF, CF, WR, SC, VF, WF, 
XF, SH and BB. A one 
in the mask fields 

forces the corre- 
sponding ALU input 

bit to a zero. 


16-bit literal Part of 
constant consisting constant 
of the ones com- 

plement of fields 

MF, CF, WR, SC, VF, 

WF, XF, SH and BB 


NOTE: When the 16-bit literal or mask is used, the ALU 
mode is forced to the arithmetic mode if the FF field bit 1 
is a zero and to the logical mode if the FF field bit 1 is a 
one. A carry of zero is forced. The ALU output may not be 
written into any general register in this case. The WR field, 
which would specify such an operation is disabled for use 
as part of the 16-bit literal or mask. 
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Processor Status Word 


The processor status word may be applied to the ALU input 
B bus when the LB field equals 01 and the BB field equals 
0011. Processor status bits are assigned as follows: 

Bit Function Name 

00 Not used (logic 1) 

01 Supervisor mode flag SUPR 

02 ALU zero flag ALUZ 

03 Shift counter bit 00 

04 Shift counter bit Ol 

05 Shift counter bit 02 


O6 Shift counter bit 03 


07 Shift counter bit 04 


08 Overflow flag OVFL 
09 ALU all ones flag ALUO 
10 ALU sign flag ALUS 
11 ALU carry tiag ALUC 


12 Processor key register 
bit 0 


13 Processor key register 
bit 1 


14 Processor key register 
bit 2 


15 Processor key register 
bit 3 


2.2.2 ALU Functions 


Two sources for data, an action to be performed by the 
arithmetic and logic unit and a destination for the result 
are all specified in a single microinstruction. 


The ALU function is determined by three fields in 
microinstruction. These fields. function, mode and carry, 
are grouped together to give meaningful names to some 
common operations, like ADD for addition. This entire 
group of fields can be set to execute combinations which 
do not have convenient names in the assembler. 


One basic ALU action or an operator is chosen. There are 
three categories of operations. Arithmetic operations 
available at this level include addition, subtraction, 
increment etc. Logical operators which have convenient 


single-word names are AND, OR, exclusive OR, NOT 
implication and equivalence. Also the ALU can perform 
more complicated logical functions explained later in this 
section. 


Table 2-3 lists some of the more common arithmetic and 
logical operations and the corresponding fields. 


Table 2-3. ALU Operations 


Assembler ALU 


Mnemonic Action FF MF CF 
ZERO all Zeros) 0011 1 00 
ONES FFFF 1100 1 00 
TRNA A 1141 1 00 
TRNB B 1010 1 00 
INCA A+ 1 0000 ) 11 
DECA A-1 1104 is) 00 
ADD A+B 1001 G 00 
SuB* A-B 0110 0 "1 
SHFA A+A 1100 0 00 
AND AAB 1011 1 00 
OR AVB 0001 0 00 
EOR Aw 8B 0110 1 00 
NOTA A 00001 00 
NOTB* B 01011 00 


*cannot be used when input B is mask or literal 
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ALU Mode 


There are two modes available for the ALU, arithmetic and 
logical. In the arithmetic mode the user selects a type of 
carry input to the ALU to be used with the arithmetic 
action. In logical functions the value of the carry field (CF) 
is ignored. The mode is directly set as either arithmetic or 
logical by the MF. field. Indirectly the mode can be set 
when the actual mode field is part of a literal or literal 
mask. If the LB field is 10 or 11 in binary, the MF and CF 
fields are part of a 16-bit constant. In this case the ALU 
mode is taken from the bit 1 setting of the FF field 
(consequently this limits the functions available with a 
literal or mask). 


Carry Flag 


The CF field specifies carry input to the ALU in the 
arithmetic mode as follows: 


CF Value of Carry In 


00 Zero 

01 Stored carry 

10 Stored carry complement 
1] One 


The carry flag ALUC, bit 11 of STAT, is altered only if SF is 
set to zero or two, TF to zero and the GF field to XX1X. 


Under these conditions carry is set or reset to the carry 
produced by the ALU. The only meaningful conditions for 
carry are the arithmetic functions such as add, increment, 
decrement and subtract. For these conditions the carry 
flag is set as follows. MF is zero for ail of the following. 
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Table 2-4. Carry Flag Settings 


’ Set if result = 0 
Set if result = 0 


if Carry In = 1 —_ 


FF —__s#Function ? if Carry In = 0 = 

0000 A Reset 

0601 AVB Reset 

0010 AvB Reset 

oo11 1 : Reset 

0100 =A+(AAB) X 

0101 (AVB)+(AA8)  _—sX 

0110 A-B-1 Set if [(A,, = B,,) A (A2 B)]v 


(A, # Bi.) A (A < 99] 


a i a a a NN TT 


0111 (AA B)-1 


Set if result is « —1 
1000, A+(AAB) xX 


1001 A+B Set if 
((A,; # BJA 
(Ai, = O)A 
(IAI > IBD] Vv 
(Ai, = BLA 
(B,, = OVA 
Pee ee ae eee iBI > IAI] 
1010 =(A Vv B) + (AAB) X 
1011 (A AB) —1 Set if result # —1 
1100 A+A Set if A,, = 1 
1101. (AVB)+A x 
1110 (AV B) +A x 


i a ea 


Set if result = —1 


Arithmetic Operations 


The FF field determines an arithmetic operation as 
indicated below when the MF field is 0. Carry input is set 
independently. When bit 1 of FF is zero the arithmetic 
mode is selected when the actual mode field is part of a 
mask or literal. The expressions in parentheses are 
evaluated first from left to r.ght. Any further evaluation is 
performed from left to right. 


Logical Operations 


When MF is one, the logical operations occur as indicated 
below by FF field settings. The carry field is ignored. 
Symbol indicates exclusive OR operation. 
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[(A<O)A (B< O)}V 


Set if result = 0 
Set unconditionally 
X 

X 


Set if ((A,, = B,,) A(A > B)] Vv 
((A,, = B,.) A (A < O)] 


Set unconditionally 
X 
Set if 


(A <0) A(B<O)]V 


(Ai,* Bi) A (Ay = O)A 


(A 2 B)]V 


[(A,, - B,.) A (8,5 = O)A 
(B > A)j v [Result = O} 


X 


__Set unconditionally 


If A, = 1 


x 
x 


Set unconditionally 


Arithmetic Functions 


FF Value 


TMMOAQADWPFPOANWAAGAWN —$ OC 


ALU Action 

A F 
AVB 

AVB 

All ones 

A + (AAB) 
(AV B) + (A AB) 
A—B—1 

(AA B)—1 

A+ (AAB) 
A+B 

(AV B) + (AAB) 
(A A B) —1- 
A+A 

(AV B) +A 
(AV B) +A 
A—1 


SYMBOLS 

V Inclusive OR 
Exclusive OR 
+ Addition 

— Subtraction 

“Logical AND 
€ Complement 


Logical Functions 


FF Value 


TNMOUODPOCMNONAWN—O 


ALU Action - 


> 


> Pid 
wos 
Cwo 
re) 
és) 


Ob) >i> > OD 
qi<>X > 
oomo ow 


AAB 
All ones 
AVB 
AV B 
A 
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2.2.3 ALU Output Destinations 


The ALU output will be determined by the function 
performed. This data can be directed by the microinstruc- 
tion to the general-purpose registers, some of the special 
registers, counters, and indirectly to memory and I/O. 


A multiple destination can be one of the general-purpose 
registers and a special register. 


The direct assignments of the ALU result is specified by a 
combination of fields, WR, LB, AA and RF. The first three 
are used to specify any one of the 16 general-purpose 
registers while RF selects sending data to the program 
counter, operand register, shift counter or key register. 


Table 2-5. ALU Output Data Destination 


Destination 


DIRECT CONTROL 


General register (any 1 of 
16) (Specified in AA) 


Program counter 

Operand register 

Shift counter 

Processor key register 
INDIRECT MEMORY CONTROL 
NOTE: Transfer occurs only 

if cycle is successfully 
initiated) 

Memory data bus 


Memory address register 


Memory input register and 
instruction buffer 


INDIRECT 1/0 CONTROL 
I/O register 


NOTE: Transfer is under 
direct control of I/O 
control. Operation is 
specified by TS, AB, MR 
fields and contents of 
1/0 control store. 


Control Fields 
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2.2.4 Other Registers 


Shift Counter 


The shift counter is an 8-bit counter which may be 
incremented and tested independent of the ALU. It is thus 
useful in keeping track of iteration in a rnicroprogram. The 
counter may be tested for overflow using test addressing. 
The overflow condition occurs when the shift counter is 
minus one. The shift counter is cleared by the decoding 
selection. When the shift counter bit 2 is true, the MIRS 
test detects a zero for MIRS- independent of MIR 
contents. 


An instruction which both increments and tests the shift 
counter tests the old value. If the counter is loaded with 
negative number and incremented to 0, the one instruction 
delay is no problem. This is because checking the old value 
for - 1 produces the same result as checking the new value 
for zero. 


Program Counter 


The program counter is a 16-bit register which can be 
incremented and/or used as a memory address, indepen: 
dent of the ALU. The following are considerations when 
incrementing the program counter: 


a. if the same microinstruction uses the P register for a 
memory address, the new value of P will be used. 


b. if the microinstruction both increments P and uses P as 
an ALU input, unpredicatable results are obtained. In 
general, using P as an ALU input and incrementing P 
should not be done in the same instruction. 


Processor Key Register (KEY) 


A 4-bit processor key register supplies signals for memory 
operations initiated by the processor. These four bits in 
conjunction with the high-order bits of the normal memory 
address are used by the memory map option determine 
physical addresses. It should be noted that this key register 
is different from the map register used under VORTEX lI. 
The latter is loaded over |1/O and cannot be conveniently 
accessed from the micro level. 


1/0 Key Register 


A similar key register for 1/O is a 4-bit register which 
supplies signals to the memory map option during memory 
operations initiated by the |/O control. 


Operand Register 


The operand register is a 16-bit register which has special 
shifting abilities. As previously noted, the ALU input A bus 
may have any of the 16 general-purpose applied shifted left 
or right one-bit positions. In addition, the operand register 
may be shifted left or right independently or in conjunction 
with shifting of any general register. This can occur any 
time the 16-bit literal or mask is not in use. The operand 
register shift occurs at the end of the microinstruction. 
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When the LB field is equal to OX (no literal/mask) the SC 
WF and *F fields define operand register shifting. 


When the SC field equals 0 no shifting takes place. When 
the SC field equals 1, the operand register is shifted left if 
the WF field equals O and right if the WF field equals 1. 


For left shifts the next contents of the operand register bit 
00 is specified by the XF field. !f XF equals 00 operand 
register bit 15 is copied to bit 00 to permit independent 
circular shifting. If XF equals O1 bit 15 of the general 
register specified by the AA field is copied to bit 00. 

This permits double-length circular shifting. If XF = 10 the 
complement of the ALU output bit 15 is copied to bit 00. If 
XF = 11 the operand register bit 00 is set to zero. 

For right shifts the next contents of the operand register bit 
15 is Specified by the XF field. If XF equals 00 operand 


register bit 00 is copied to bit 15 to permit independent 
circular shifting. If XF equals O1 bit 00 of the general 


Table 2-6. Operand Register Shift Operations 


Control! Field 


No shifting 

No shifting 1X 

Shifting of operand register | Ox 
Left shifting 


Bit OO = operand 
register bit 15 


Bit OO = general 
register bit 15 
(specified in AA) 


Bit OO = ALU bit 15 
complement 


Bit OO = zero 
Right shifting 


Bit 15 = operand 
register bit 00 


Bit 15 = general 
register bit 00 
(specified in AA) 


Bit 15 = operand 
register bit 15 


Bit 15 = SHFT (shift 
flag) 


register specified by the AA field is copied to bit 15 to 
permit double-length circular. shifting. If XF equals 10 the 
operand register bit 15 is maintained at its current state 
to permit independent arithmetic shifting. If XF equals 11 
the shift flag (SHFT) is copied to bit 15. 


2.3 ADDRESSING 


2.3.1 General 


Executing instructions in an order other than strictly 
sequential gives programs flexibility and compactness. The 
ways in which the order of microinstructions can be varied 
are similar to those used in assembly-language programs. 
For the microassembler the usual order of execution takes 
the next instruction -- the contents of word five after word 
four and so on -- unless a jump or branch specifies the 
change in order. In reality each and every microinstruction 
Specifies the next one to be executed, but usually the 
assembler constructs sequential-execution addressing 
automatically. 


A jump in a microprogram can be a conditional action 
based on the true or false state of flags or signais in the 
system. In microinstructions the jump is not a separate 
instruction but the sampling and/or testing and the 
branch itself are specified in fields of a microword. In 
addition to conditional and unconditional branches, the 
branch may be from one page to another. The page jump 
is described following a few simpler cases and conditions. 


Three basic types of addressing create the address of the 
next microinstruction to be executed. Normal addressing is 
the simplest case. The next address is specified by the 
current microinstruction. Field-selection addressing uses 
an instruction register field to specify the address for the 
next microinstruction. In decoding addressing (using the 
decoder control store) the instruction buffer specifies the 
next address (section 8 in this manual describes the use of 
this feature). 


Three other types of addressing are similar to the basic 
types. Conditional addressing uses testing of various 
conditions to choose one of two addresses. The page jump 
can specify both the page and word number within the 
page for the next microinstruction. Interrupt addressing 
uses both the microinstruction and the system's interrupt 
logic to determine the next microinstruction. 


2.3.2 Normal Addressing 


Normal addressing is used to arbitrarily specify the next 
microinstruction address. No conditional testing is 
involved, no interrupts are active or they are disabled and 
decoder addressing is not specified. The FS and TS fields 
are set equal to 0000 and the MT field equals 0 so the low 
order address contribution (bits 0-3) is governed entirely 
by the MS field. The high order bits (4-8) are supplied by 
the AF field. 
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Control Store Address -- 
Normal Addressing 


No reset 

No interrupts 
No decoding 
FS = 0000 
MT = 0 

TS = 0000 or 
TF = 0 


Normal Addressing with TS Field 


The TS field may be used to form bits 1 through 4 of the 
control store address when none of the following 
conditions is true: 


a. Register field extraction (AB field equals 01 or 10) 


b. Interrupts allowed (SF and TF field both 00; GF field 
equals X1XX) 


c. t/Orequest (SF field equals 00; IM field equals 111X) 


d. Page jump (TF field equals 00; SF field equals 10; GF 
field equals X1XX) 


The address is formed by the inclusive OR of the TS field 
into bits 1 through 4 of the address obtained with normal 
addressing (FS field equals to 0000; no decoding; nc 
interrupts, MT field equals 0). 


inclusive or 


fofofofof 1s fo! 


Control Store Address 
Normal Addressing with 
TS Field 


2.3.3 Field Selection Addressing 


The contents of the instruction register and a number of 
processor flags may be used to form a control store 
address. Any 1- to 5-bit contiguous field from the 
instruction register may also be used in forming the low- 
order five bits of control store address. Thus, up to a 32- 
way branch may be performed based on instruction 
register contents. This permits detailed instruction decod- 
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ing. In addition, the interrupt flag, byte address flag, shift 
flag and console step mode may be selected to alter the 
control store address. 


Field selection addressing is used any time the FS field is 
not equal to 0000. The field selection address contribution 
for all values of the FS field is shown in the tables below. 
Any bit of the field selection contribution may be forced to 
a zero by use of the MS and MT fields. The field masks bits 
0-3 of the field select contribution. The MS field masks bit 
4. A zero in any bit of the MS and MT fields forces the 
contribution of the corresponding field selection bit to zero. 
When an !/O request is issued (SF field equal to 00 and IM 
field equal to 111X) the MT field is used as part of the 1/0 
operation specification. in this case, the MT field is ignored 
and bit 4 of the field selection address contribution is 
masked to zero. 


The field selection address contribution is shown below for 
all values of the FS field. 


High-order address bits 4 through 8 are provided by the AF 
field. 


The TS field is logically ORed into the control store address 
bits 1 through 4 under the same conditions as normal 
addressing into TS field. Thus, the composite field selection 
address is formed as follows: 


Control Store Address Bit 
2 FS Field 


Numbers 00 through 15 refer to instruction register bits 
INT is the interrupt flag (complement) 

BYTA is the byte address flag 

SHFT is the shift flag 

STEP is true when the console is in the STEP mode 


Figure 2-3. Field Selection Address Contribution 
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inclusive 


inclusive 


or 
PERT ==, | 
and 


Control Store 
Address Field 
Selection 


* TS field is not used in bits 1-4 of address formation 
when: 


a. Register field extraction (AB field equals 01 or 10) 


b. Interrupts allowed (SF, TF fields both 00, IM field 
equals 111X) 


c. |l/Orequest (SF field equals 00; IM field equals 111X) 


d. Page jump (TF fiéld equals 00; SF field equals 10; GF 
field equals X1 XX) 


e. Test addressing ts specified (TF field not equal 00) 
** (FS) is the contents of the field specified by the FS field 


**% MT 1s replaced by a zero when an I/O request is 
present (SF field equals 00; IM field equals 111%) 


Normal addressing and normal addressing with TS field 
are a subset of the field selection addressing set, i.e., the 
FS field equals 0000 and the MT field equals 0. 


2.3.4 Test Addressing 


Two addresses must be specified when test operations are 
performed -- one for use if the test passes and one for use 
if it fails. Testing is specified whenever the TF field is not 
equal to OO. If the test is to pass when the condition tested 
is true, the TF field must be equal to 10. If the test is to 
pass when the condition tested is false, the TF field must 
be equal to 11. The condition to be tested is specified by 
the GF field. 


The address used if the test passes is identical to that 
formed by field selection addressing. The address used if 
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test fails is made up of the AF and TS fields as shown 1OSR__—_—-'1/O Sense Response (discussed in !/O section) 


below. 
SSW3, Sense switches are set and reset 
SSWw2 only by manual manipulation on the 
and control panel. 
SSW1 
TFIR ‘Test from instruction register which determines a 
inclusive set of conditions tested simultaneously. Nine bits of 
or the instruction register cause the following tests: 
0 Overflow 
fofofolo| ts fo. 1 Positive/NOT bit 
2 Negative/NOT bit 
Control! Store Address -- 3 ROofGeneral-purpose registers 
Test Fails 4 RI of General-purpose registers 
5 R2 of General-purpose registers 
6 Sense switch 1 
2.3.4.1 Conditions 7 Sense switch 2 
8 Sense switch 3 


Whether or not a test is to be done and the way the test 

passes are indicated in the test field (TF). Testing is ALUO ALU all ones 
specified whenever the TF is not zero. If the test is to pass 
when the condition is true, the TF is equal to 10. If the test 
is to pass when the condition is false, the value of the TF 
should be 11. ALUC ALU carry flag 


ALUS ALU sign flag 


The condition to be tested is specified in the GF field. ALUZ ALU alli zeroes 


SHFT Shift flag copies bit 15 of the general register 
specified in the AA field whenever the literal or mask is 


Summary of Conditions Mnemonics 
not being used and the VF value is 1. This flag may 


Value of Mnemonic be shifted into the operand register bit 15. It may be 

GF for Assembler tested by a microinstruction to cause a branch to 
either of two microinstructions. 

6) OVFL 
1 !OSR MIRS Memory input register sign. This test is invalid 
2 SSW3 when the shift counter bit 2 is ture (i.e., equals 1). 
3 SSW2 SFTC Overflow of the shift counter 
4 ssw} 
5 TFIR GPRS General-purpose register 0 bit 15 (sign) 
6 ALUO 
7 ALUS NORM Normalize flag is set after any microinstruction 
8 ALUC which the ALU output bus bit 15 is not equal to bit 14. It 
9 ALUZ will be reset after any microinstruction during which 
A SHFT the ALU output bus bits 14 and 15 are the same. 
B MIRS 
C SFTC QUOS Quotient flag copies bit 15 of the ALU output after 
D GPRS a microinstruction in which the literal or mask is not 
E NORM beimg used and the WF value is 1 and SC field is zero. 
F QUOS 


MULS Multiply sign sets any microinstruction during 
which any of the following three conditions existed: 
1, ALU output bit 15 and ALU input A bit 15 were 
both equal to 1 
2. ALU output bit 15 and ALU input B bit 15 were 
both equal to 1 
3. ALU input A bit 15 and input B bit 15 were both 
equal to 1. 


Meanings and Use of Conditions 


OVFL Overflow may be set and reset unconditionally. It 
may sample data-loop conditions. Automatically reset 
by system reset or microinstruction in which the GF 


value is TFIR and the instruction register bit 0 is set 
and the test met. 


This flag may be appliec to the ALU :~...:* A bus during 
right shift operations 
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BYTA Byte address flag copies bit 00 of the general 
register specified by the AA field whenever a general- 
purpose register is specified as shifted input to the 
ALU input A bus. This flag may be used to determine 
the address of the next microinstruction and for 
memory byte store operations (SF not equal to zero 
and |M field equal XX11) determines which byte of 
the addressed memory location is to be altered. If 
BYTA equals zero, the left byte is selected. BYTA 
equal to one selects the right byte. BYTA is set or 
reset during the microinstruction rather than at the 
end. 


A wide variety of flags are available for use in micropro- 
gramming. In general, tmey may be tested no sooner than 
the microinstruction after which they were set. In other 
words, a microinstruction which both changes a flag and 
tests will be testing the old value of the flag. 


The conditions that cause a flag to be set depend on the 
particular flag. In addition some flags require that the 
microinstruction specify sampling before they will be set. 
For example, the ALU all zeros (ALUZ) flag will not be set 


untess the ALU is all zeros and sampling is requested. 


The following table lists some of the major flags. ALUZ, 
ALUC, ALUS, and ALUO are sampled together by any 
microinstruction in which SF equals XO, TF equals zero, 
and GF equals XX1X. 


Summary of flags requiring sampling for microprogrammed 
conditions. 


Flag Sampling 
NORM no 
MULS no 
SHFT yes VF 
QUOS yes WF 
BYTA no GPR shift right or left 
OVFL yes sample overflow 
A 

one bie sample conditional test 
ALUC yes 

(GF = xxlx, TF =00, 

ALUO yes SF = 00 10 
ALUS yes a O0rer ae) 
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Table 2-7. Overflow Flag Control 
OVERFLOW FLAG CONTROL 


Conditions 


Operations Fields Bit 15 


ALU Input | ALU Output 

TF. SF GF OFF | BB | 
Set overflow 00 01 X0O1X Pd 
Reset overflow 00 Ol X10X Fae 

l 

¢) 

4 

x 

0 

l 

x 

x 


(ADD) 


Sample overflow 00 Ol X11X 
SET 


DON'T SET” 


oOonmr O 
ee DS ot OD. 


(SUBTRACT) 


SET 


DON'T SET" 


-_- On” Oo 


Also, reset by system reset or a microinstruction specifying 
test of the 620/f test condition with the instruction 
register bit 00 on in which the test passes. 


Overflow may be sampled to be set if SF = 00 and GF = 
1XXX. It will not be reset even if no overflow exists. 


* If set previously, overflow will remain set regardless of 
sampling conditions. 


2.3.4.2 Addresses in Branches 


The destination address when the test fails must be an 
even word address. The destination addresses of both the 
pass and fail conditions must be within 32 words of each 
other. This means that the upper 4 bits of the addresses must 
be the same. 


Procedure for Address Assignment 
Following completion of a flowchart assignment of control 


store, address assignment may be performed. A useful 
procedure is: 


1. Assign the microprogram entry addresses consistent 
with the desired format of the BCS instructions. 


iS) 


Assign addresses to micrainstructions to be executed 
upon receipt of an interrupt. These addresses must be 
X XXXX 0111. 


3. Assign addresses to all microinstructions to be 
executed following those using TEST ADDRESSING 
where the ‘test fails’ condition prevats. 


4. Assign addresses to all microinstructions to be 
executed by field selection addressing. If field selection 
specifies test of the interrupt, byte address, shift, or 
console step flags assign addresses to the microin- 
structions to be executed in accordance with the 
following restrictions: 


Flag On Flag Off 
Interrupt X XXXXXXXXO XXXXXXXX1 
Byte Address X XXXXXXXX1 XXKKKKAKO 
Shift KX KXXKXAXAX1X AMKXKXXKOK 


Console Step X XXXXXXXX4 KRKXXKXKKXXG 


5. Recheck ali field select and test addressing 
microinstructions for addressing consistency. Prepare 
a list of assigned addresses and _ corresponding 
microinstruction numbers labels (keyed to the flow- 
chart) to avoid duplicate assignments. 


6. Other microinstructions may have their addresses 
arbitrarily assigned by the programmer or the 
assembler. 
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2.3.5 Page Jump Addressing 


The microinstruction specifies a branch to a location in 
another 512-word page by executing a page jump. In this 
case, a 13-bit address is generated which sets a new active 
page number and specifies an address within that page. 
The page number is specified by the TS field. The word 
address is specified by field select addressing. 


TS Address modified field 
select addressing 
Contro! store address 
page jump 


A Page Jump with memory is specified by the TF field equal 
to 00; the SF field equal to 10; and the GF field equal to 
X1XX. 


A page jump without initiating a memory cycle is specified 
by setting the TF and SF fields to zero, and the IM field = 
0011. 


2.3.6 Interrupt Addressing 


When interrupts are allowed and an interrupt is active in a 
class which is enabled by the TS field, the low-order four 
bits of the control store address are supplied by the 
interrupt logic and the high order bits from the AF field. 


IIA is supplied by interrupt logic. 


1A is 7 for interrupts and 1 for second tests of interrupts 
after initiation of the 1/O imterrupt sequence. Note: The 
second test and i/O start must occur together in the same 
microinstruction. 


The TS field enables interrupts whenever bits arc set as 
follows: 


Bit Set Enables 


0 1/O interrupts 

1 1/0 interrupts only if memory 
protection is installed 

2 Memory protection interrupt 

3 STEP, console step mode interrupt 


2.4 MAIN MEMORY CONTROL 


Memory access may be initiated in a microinstruction 
which indicates the type of operation and the address 
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source. Main memory access includes the fetching and 
storing of data to and from the memory through the 
memory buses. Memory can either be the core or 
semiconductor variety (as distinct from the disc or drum 
storage often called rotating memory, which is accessed as 
a peripheral device through 1/0 facilities). 


When a microinstruction initiates an access, the memory 
control section handles the complete operation. This 
permits the microprogram to initiate access to/from 
memory and perform other functions (ALU etc.) while the 
access actually occurs the microprogram can detect the 
completion of the memory access by specifying a wait for 
memory done. 


Two different types of fetches can be requested. The 
instruction fetch (IF) moves the contents of a 16-bit word 
from main memory to the memory input register (MIR) 
and the instruction buffer (IBR). The operand fetch (OF) 
moves a 16-bit word to the memory input register and does 
not change the instruction buffer. Instruction fetches are 
usually used for fetching 16-bit macroinstructions for 
decoding from the IBR. The operand fetch is used for 
general data and address fetches. The microword which 
requests a fetch provides the address in main memory. 
After the request is made it is handled completely by 
memory control and requires no further actions in the 
following microinstructions. 


Example of fetch sequence 


request wait for (data its 


instruction memory | ready for 


fetch done use in MIR) 


Memory requests to store data are of two types. The first is 
the operand store (OS), which stores a 16-bit word in main 
memory. The second is the byte store (BS), which stores 
only an 8-bit byte. As with the fetch operations, the 
microinstruction which requests the store must furnish the 
main-memory address for the operation. Microinstructions 
following the request for a store must provide the data to 
be stored on the ALU until the memory operation is 
complete. 


Example of store sequence 


RO —> ALU] (operation 
complete) 


request store 


using P as wait for 
address memory 
done 


During operand stores, the memory data are derived from 
the ALU output. If the ALU input is from any of the 16 
general-purpose registers and an arithmetic operation is 
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specified for the ALU, incorrect parity data may be stored 
in memory. This situation can be avoided by using only 
logical ALU functions during operand stores; or by 
addressing the general-purpose register to the proper ALU 
input during the microinstruction that initiates the memory 
store cycle. Figure 2-4 is a coding example of an operand. 
store sequence using an arithmetic operation with a 
general-purpose register as the data source. 


Completion of a memory operation is detected either with 
the wait-for-memory-done function or by requesting another 
memory operation. Wait-for-memory-done suspends mi- 
croinstruction execution until the memory operation is 
complete. Requesting another memory operation has the 
same effect because microword cannot complete until its 
memory request is acknowledged by memory control and 
requests are not acknowledged until any previous request 
is complete. 


Override 


An active memory access may have the type of operation 
changed by the next microinstruction. By making an 
immediate change the immediately prior action is overrid- 
den. This can be conditional upon the result of the same 
test available for addressing (GF field). 


Example: 


Microinstruction 
Cycle n+2 


Microinstruction Microinstruction 
Cycle n Cycle n+1 


Initiate memory memory 
memory store -Store 
store starts 


continues 


override too late 
possible to override 


Memory cycles may be initiated by microinstructions either 
unconditionally or depending on the results of a test. 


2.4.1 Unconditional Cycle Initiation 


A memory cycle is unconditionally initiated or overridden 
when the SF field equals 01 or if the SF field equals 10 and 
the TF field equals 00. 


The IM field specifies the type of operation and the address 
source. Permitted operations are: 


IM Value _ Action 


XX00 Read data from memory into the instruction 
buffer and memory input register (instruction fetch). 


XX01 Read data from memory into the memory input 
register (operand or address fetch). 
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CAPABILITIES 


IM Value Action 


XX10 Write the full word output of the ALU into memory. 


XX11 Write the byte from the ALU specified by the byte 
address flag (BYTA) into the corresponding memory 
byte. The other memory byte at the designated word 
address is unaffected. If BYTA is false, the left byte is 
written. If BYTA is true, the right byte is written. 


BYTA, the byte address flag, copies bit 0 of the general 
register specified by the AA field whenever a general- 
purpose register is specified as shifted input to the 
ALU input A bus. 


The operation may be changed by the following microin- 
struction by specifying the new operation with the !M field 
equal to OOXX. This permits, for example, conversion of a 
store cycle into a fetch or an instruction fetch into an 
operand fetch. 


The data to be written to memory must be maintained at 
the ALU output by the microinstruction(s) following 
initiation until the cycle is complete. 


The source to be used for loading the memory address 
register is specified as follows: 


IM = Q1XX ALU output 
IM = 10XX Program counter 
IM == 11XX Memory input register 


2.4.2 Conditional Cycle Initiation 


A memory cycle may be initiated (or overridden) or not 
depending on the results of a test specified by the GF field. 
Conditions tested were described previously in the section 
of test addressing. 


if the TF field is not equal to 00 and the SF field equals 10, 
the cycle will be initiated (or overridden) if the tested 
condition is false. 


lf the SF field is equal to 11, the cycle will be initiated (or 
overridden) if the tested condition is true. 


In either case, the IM field specifies the operation to be 
performed and the address source to be used as described 
in the previous section. 


2.4.3 Special Transfer 


ALU output data may be transferred to the instruction 
buffer and memory input register by using the memory 
data bus. This does not involve activation of any memory 
module. To initiate this transfer the SF field must be equal 
to 00 and the IM field equal to 0100. The ALU output data 
must be set up by the initiating microinstruction and 
maintained for one more microinstruction. 
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2.4.4 Wait for Memory Done 


The wait-for-memory-done function suspends microinstruc- 
tion execution until memory control signals completion of 
central control's prior request. This function is SF = 0 and 
IM = 0001. If no central control has no prior request 
active, the wait-for-memory-done has no effect. 


Table 2-8. Memory Operations 
Control Field 
Function SF TF IM 


UNCONDITIONAL INITIATION 


CONDITIONAL INITIATION 
Condition True 


Condition False 
(Condition Specified in GF) 


EITHER 


Operation 
Read memory data into 
instruction buffer and 
memory input register 


Read memory data into 
memory input register 


Write ALU word output 
Write ALU byte output 


Address Source or Override 
Override operation 


ALU output 


Program counter 


Memory input register 


SPECIAL TRANSFER 
(ALU output to Instruction 
buffer and memory input 
register) 


2.5 MICROPROGRAMMING EXAMPLE 


General 


As an example of instruction implementation using 
microprogramming, the steps of a single-word address- 
ing load accumulator LDA in the direct address mode will 
be traced. 


SS1M 


Initially the instruction pipeline is assumed to be empty so 
a new instruction must be fetched from main memory. The 


tirst microinstruction studied will be that obtained from 
control store location 13E (all addresses are given in 
hexadecimal). This location has the label SS1M, which is 
one of the microprogram's standard states. 


The microinstruction fields at 13E are: 


TS AF MS MT FS TF SF GF 
0000 01001 0010 0 0000 00 01 0000 


MR AB IM LB LA RF’ FF MF 
0 00 1000 00 00 000 0000 0 


CF WR SC VF WF XF SH. BB AA 

00 0 oO O 90 00 000 0000 0000 
The function of this microinstruction is to initiate an 
instruction fetch from the memory address specified by 
the program counter. Note that the SF field equal to 01 
specifies unconditional initiation of the memory cycle. The 
IM field specifies use of the program counter for an 
address source and_ the instruction buffer and memory 
input register as destinations for data received from 
memory. The FS, MT, TS and TF fields contain all zeros so 
normal mode addressing is specified. The next control store 
address will be 092. No other fields of the microinstruction 
are pertinent. 


$S2M 


Location 092 is another microprogram standard state 
labeled SS2M._ It continues the process of filling the 
pipeline by initiating another instruction fetch using the 
incremented contents of the program counter. 


The microinstruction fields at 092 are: 


TS AF MS MT FS TF SF GF 
0000 00010 1101 0 0000 00 01 0000 


MR AB IM LB LA RF FF MF 
Oo 00 1000 00 00 100 0000 0 


CF WR SC VF WF XF SH_ BB AA 
00 0 0 O 0 00 000 0000 0000 


Again the SF field is equal to 01 and the |M field is equal to 
1000 specifying another instruction fetch using the 
program counter. In this case, however, the RF field equals 
100 specifying that the program counter will be  incre- 
mented before it is used an address. This microinstruction 
will not be immediately executed as the previous microin- 
Struction initiated memory activity and the memory 

interface will remain busy until the first instruction from 
memory is loaded into the instruction buffer and the 
memory input register. At the time, the current microin- 
struction completes and the next microinstruction from 

location O2D becomes active. Normal addressing occurs 
again due to FS, TS, MT and TF fields being zero. No other 
fields of the microinstruction are pertinent. 


CAPABILITIES 


SS3M 


Location 02D is another microprogram standard state 
labeled "'SS3M". It causes decoding of the instruction 
fetched from memory while checking for interrupts. It also 
copies the instruction buffer into the instruction register to 
make room for the next instruction from memory. 


The microinstruction fields at 02D are: 


TS AF MS MT FS TF SF GF 
1110 01101 0110 0 0000 00 00 0101 


MR AB IM LB LA RF FF MF 
0 00 0110 00 00 000 0000 0 


CF WR SC VF WF XF SH_ BB AA 
00 0 0 0 0 00 000 0000 0000 


This microinstruction manipulates no data paths nor does 
it initiate any memory cycles. Its sole purpose is to check 
for interrupts and, if there are none, cause a branch to the 
required microsequence. The TF field is equal to 0 and the 
GF field bit O is a one causing data transfer from the 
instruction buffer to the instruction register. With the SF 
field equal to 00 and the GF field bit 2 equal to one, 
interrupts and decoder addressing are enabled. The TS 
field defines the interrupts which are enabled -- all except 
1/O interrupts unless the memory protect option is 
installed. The {M field specifies selection of the interrupt 
flag. If this flag were set, interrupts would be suppressed. 
The flag is reset by this microinstruction. If an interrupt 
were active and the interrupt flag had not been set, the 
next control store address would be ODX where X 
designates the four bits supplied by the interrupt logic. This 
would produce a branch to the interrupt microprogram 
sequence. 


Assuming no interrupts are present, the new control store 
address will be determined by the decoder logic. The 
instruction fetched from memory is assumed to be 10F9 
(hexadecimal) or 010371 (octal). This is a V73 "LDA" 
instruction with direct addressing of location OOF9 (hex- 
adecimal). The most significant four bits of the instruction 
buffer address the first decoder control store at location 
one. The next four bits address the second decoder control 
store at location 00. The decoder control store contents 
are: 


Ist decoder 


Control store Bl2 = 1 
location 1 B8-BO = 110000010 
2nd decoder 


Control store A8-AO0 = 010000000 


location 0 
Since Bl2 equals 1, the B8-BO and A8-AO address 


components are logically ORed to produce an address of 
182. 
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CAPABILITIES 


SWA10 


Location 182 contains the first microinstruction of the 
single word addressing sequence (SWAI10) for the 
instruction fetched from memory. It forms the effective 
address by masking bits 00 through 10 from the 
instruction register. It also initiates the operand fetch. 


The microinstruction fields at 182 are: 


TS AF MS MT FS TF SF GF 
0000 10010 1111 0 0000 00 01 0000 


MR AB IM LB LA RF FF 
_90 00 0101 10 00 011 1010 


MF CF WR SC VF WF XF SH BB AA 
1 11°11 #1 +O 0 00 000 0000 0000 
t ‘ 


“+ ----- "> 16-bit mask literal--- 7-7-7 = 


The LB field equals 10 so the ALU B input bus will have the 
contents of the instruction register masked by the 16 bits 
of the MF, CF, WR, SC, VF, WF, XF, SH and BB fields (a 
zero in the mask enables the corresponding instruction 
register bit). The mask equals F800 so the low order 11 bits 
of the instruction are used. 


The ALU mode is determined by the FF field (1010) in 
conjunction with the LB field (forces logical mode) 
resulting in an ALU function of the ALU = B. 


The RF field equals 011 so the ALU output is copied into 
the operand register. 


The SF field equals 01 so unconditional memory control is 
specified by the IM field (0101) to be fetch an operand 
into the memory input register using the ALU output for 
an address source. This microinstruction will complete 
when the memory cycle initiated by the microinstruction at 
092 completes. 


The FS, TS, TF and MT fields all contain zeros so normal 


addressing is used and the AF and MS fields specify the 
next control store address of 12F. 


SWA20 


Location 12F contains the second microinstruction of the 
single word addressing sequence (SWA20). It decodes bits 
13-15 of the instruction register contents to determine the 
class of the single word addressing instruction. 


The microinstruction fields at 12F are: 


TS AF MS MT FS TF SF GF 
0000 11110 1100 1 1111 00 00 0000 


MR AB IM LB LA RF FF MF 
0 00 0000 00 00 000 0000 0 
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CF WR SC VF WF XF SH_ BB AA 
00 0 0 0 0 00 000 0000 0000 


No data manipulation or memory control operations are 
performed by this microinstruction. It serves only to 
branch to the specific microsequence for the class of 
single-word addressing instruction contained in the 
instruction register. Field select addressing is used to 
perform this decoding (FS field is not equal to 0000). The 
FS field is equal to 1111 so the selected field is bits 11 
through 15 of the instruction register. The composite: 
address formation is illustrated: 
876543210 
AF field contribution: 111100000 
o =111100000 


TS field contribution: 000000000 
Field selected from 
instruction register: 
(i) = 10F9) 


000000010 
and = 000000000 


Mask consisting of MT 04000 2 Oro 


and MS fields 


Final effective address 
produced by inclusive or 


111100000 


The address of the next microinstruction is then 1EO. 


LDA1 


Location 1EO is the first microinstruction specific to the 
LDA instruction (LDA1). 


This microinstruction increments the program counter and 
initiates another instruction fetch from main memory. 


TS AF MS MT FS TF SF GF 
0000 01011 0101 0 0000 00 01 0000 


MR AB IM LB LA RF FF MF 
0 00 1000 00 00 100 0000 0 


CF WR SC VF WF XF SH_ BB AA 
00 0 0 0 0 00 000 0000 9000 


The RF field equals 100 specifying that the program 
counter will be incremented during this microinstruction. 


The SF field equals 01 so unconditional memory control is 
specified by the IM field (1000) to fetch an instruction into 
the instruction buffer and memory input register using the 
program counter for an address source. (Note that the 


program counter is incremented during the microinstruc- 
tion so the new value will be used for the memory cycle). 


Normal addressing is used to specify the next microinstruc- 
tion address (TF, TS, FS. MT fields are all zero). The AF 
and MS fields define the address to be 0B5. 


LDA2 


Location 0B5 is the second microinstruction specific to the 
LDA instruction (LDA2). This microinstruction transfers 
the contents of the memory input register to the 
accumulator, RO; transfers the instruction buffer contain- 
ing the next instruction to the instruction register to make 
room for the instruction whose fetch was initiated by the 
microimstruction 1E0; decodes the instruction buffer to 
determine the starting address of the next microsequence 
and checks for interrupts. 


The microinstruction fields at OB5 are: 


TS AF MS MT FS TF SF GF 
1111 01101 0110 0 0000 00 00 0101 


MR AB IM LB LA RF FF MF 
0 00 0110 01 00 000 1010 1 


CF WR SC VF WF XF SH_ BB AA 
00 1 0 0 O O00 000 0001 0000 


The ALU B input is specified by the LB field (equal to 01) to 
be one of the special registers. The BB field (equal to 
0001) defines the memory input register as the source. 


The ALU operation ts specified to be in the logical mode 
(MF = 1) with the ALU output equal! to the ALU B input 
(FF = 1010). 


The WR bit equals a one so the ALU output data will be 
written into the register specified by the AA field (AA = 
0000) which is the accumulator (A register). This is the 
execution phase of the LDA instruction. 


The SF and TF ftelds are both equal to 00 and the GF field 
bit 0 is a one so the instruction buffer contents are copied 
into the instruction register. The GF field bit 2 is a one so 
the instruction decoder is enabled and interrupts are 
checked. 


The IM field equal to 0110 with the SF field equal to 00 
selects and resets the interrupt flag. If the flag is set, the 
decoded address and interrupts are suppressed and the 
next microinstruction is fetched from location ODO. All 
interrupt classes are enabled as the TS field contains all 
ones. If an interrupt is active and the interrupt flag is off, 
only the decoded address is suppressed and the next 
microinstruction is fetched from the address specified by 
the AF field and the interrupt logic. This address is ODX 
where X is the address supplied by the interrupt logic 
(X #0). 


If no active enabled interrupts exist, the next microinstruc- 
tion will be fetched from the address specified by the 
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CAPABILITIES 


SSiM (13E) 


INITIATE INSTRUCTION 
FETCH USING P 


SS2M (092) 
INCREMENT P 


INITIATE INSTRUCTION 
FETCH USING P 


SS3M (02D) 


DECODE INSTRUCTION 
BUFFER 


TRANSFER BUFFER TO 
INSTRUCTION REGISTER 


ENABLE INTERRUPTS 


SELECT AND RESET 
INTERRUPT FLAG 


SWAI0 (182) 
INSTRUCTION REGISTER 
BITS OO THRU 10 ALU 
LOAD OPERAND REGISTER 


START MEMORY OPERAND 
FETCH USING ALU 


SWA20 (12F) 


FIELD SELECT INSTRUCTION 
REGISTER BITS 13 - 15 

] = 000 

13-15 

LDAI (1E0) 
INCREMENT P 


INITIATE INSTRUCTION 
FETCH USING P 


LDA2 (OBS) 


COPY MEMORY INPUT 
REGISTER INTO RO 


TRANSFER BUFFER TO 
INSTRUCTION REGISTER 


DECODE INSTRUCTION 
BUFFER 


SELECT RESET INTERRUPT 
FLAG 


DECODED SINGLE WORD 
ADDRESSING INSTRUCTION 


Figure 2-5. Flowchart for LDA Instruction 
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1BR— | 
ENABLE 
INTERRUPTS 


Timing diagram shows the start-up and execution of a sequence of single-word addressing instructions (330 nanosecond 


memory cycle time is assumed). . 


VTII- 2084 Figure 2-6. Flow Diagram of LDA Instruction 


decoder control store logic. If the instruction buffer 
contains another single-word addressing instruction, the 
next address will be 182 (SWA10) and the sequence will be 
repeated. 


Figures 2-5 and 2-6 show a flowchart and flow diagram of 
the microinstruction sequence described. Note that the 
pipeline effect of buffering instructions permits efficient use 
of the memory. (A 330-nanosecond semiconductor memory 
was assumed). 


2.6 TIMING CONSIDERATIONS 


Most microinstruction operations take place at the conclu- 
sion of the cycle. Certain exceptions do exist. ALU inputs 
are sampled at the midpoint in time of the cycle. Control- 
store address information, memory addresses, and most 
register and flag changes occur at the end of the 
microinstruction execution. The areas below should be 
considered while planning microprograms. 


Program counter incrementation (RF = 100 or 111) 
Incrementation takes place at the midpoint of the 


2-24 


microinstruction. Thus the program counter value 
applied to the ALU input will not be the incremented 
value. The new value will be used as a memory 
address, if the program counter is specified as an 
address source. 


Byte address fiag 
The byte address flag is set or reset at the temporal 
midpoint of the microinstruction. Thus, it can be al- 
tered in the same instruction which requests a byte 
store and its new value will determine which byte of 
the memory location is to be altered. 


Memory write operations 

ALU inputs, function, mode and carry must be 
maintained constant throughout any memory write 
cycle. This is accomplished by specifying another 
memory cycle immediately following the current cycle 
thus interlocking execution of the next microinstruc- 
tion with completion of the memory cycle in progress 
or by using the wait for memory done function (SF = 
00, IM = 0001). 


Memory Input register 
The memory input register (MIR) should not be used 
as an ALU input if it can receive a new value from 


memory during that instruction. Thus, the MIR should 
not be used as an ALU input by an instruction which 
causes a wait for memory done to complete a memory 
fetch. If the microinstruction which immediately fol- 
lows a fetch request does not result in a wait for 
memory done, it can apply the MIR to the ALU and 
obtain the old value. Subsequent instructions can not 
obtain the old value and the new value can not be 
applied to the ALU until the instruction following 
memory completion. 


Note that the above discussion only applies to the 
MIR as an ALU input. The MIR can be used as a 
memory address source during the same instruction 
in which it is changing. In this case, the new value 
just received from memory will be used as the memory 
address. 


Special transfers 
The transfer of ALU data to the instruction buffer and 
memory input register requires ALU data to be 
maintained for two microinstructions. 


1/0 operations 
If the |1/O section is not idle when a new I/O operation is 
specified, microinstruction execution will not occur 
until the 1/O becomes idle. A wait for i/O done 
function (SF = 00, and IM = 0010) will cause a 
similar wait condition until the !/O DN bit becomes 
true. 


Use of the I/O register 
If direct memory access or similar |/O operations are 
possible the |/O register may be altered. Care in use of 
this register is indicated. Control of the !/O register is 
described in the 1/O section of this guide. 


2.7 ADDITIONAL CAPABILITIES 


2.7.1 Register Field Control 


Many types of instruction words contain fields which 
specify registers which contain operand data. If all 
combinations of operations on all possible registers had to 
be specified by individual microinstructions, the control 
store size would be quite large. 


AV70 series system permits three- or four-bit fields to be 
selected from the instruction register and stored and 
maintained in the control-buffer-register specification 
fields. This permits a single microinstruction to handle all 
combinations of registers for any operation. 


CAPABILITIES 


This register field extraction is performed independently of 
the field select addressing function and both may be used 
simultaneously. 


The AA and BB fields of the microinstruction contained in 
control store are copied into their corresponding positions 
in the control buffer any time the AB field equals 00 and 
the MR field equals 0. This is the normal mode of 
operation, 


When the SF field equals zero and no I/O request is 
active, and the AB field equals 01 or 10: the TS field 
specifies a 4-bit field of the instruction register (in the 
same manner as field select) to be loaded into the control 
buffer’s AA or BB field. The control buffer field not being 
loaded will be maintained at its last value. A code of AB = 
01 loads the selected field into the BB field. A code of AB 
= 10 loads the seiected field into the AA field. 


The MR bit is used to mask the most significant bit of the 
(TS) selected field. If MR = 0, the most significant bit of 
the selected field will be treated as zero. If MR = 1, the 
most significant bit of the selected field will be loaded 
into the designated control buffer. 


The AA and BB fields can be maintained in their current 
State by specifying an AB field equal to 11 while the SF 
field equals 00 and no I/O request is present. 


lf no 1/O request is present, the AB field equals 00 and the 
MR field equals 1, the control buffer AA field will be 
maintained at its current value and the BB field will be 
forced to either of two addresses depending on data loop 
conditions and the WF field. 


WF field equal to 1 


Operand register bit 01 = 1; BB = 1111 

Operand register bit 01 = 0; BB = 1110 
WF field equal to 0 

ALU bit 15 = 1; BB = 1111 

ALU bit 15 = 0; BB = 1110 


This function is used by the V70 series standard 
instructions microprograms for multiply and divide. 


Register field control operations are summarized in the 
tables following. 
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Table 2-9. Register Field Control 


Function SF 


Load A and 8 fields from 
control store 


Inhibit loading of A field 
and place selected 4 bit 
field (masked) from in- 
Struction register into 

B field 


Inhibit loading of B field 
and place selected 4 bit 
field (masked) from in- 
struction register into 

A field 


Inhibit loading of A and 
B fields 


Inhibit loading of A field 
and force B field to 1110 

if ALU output bit 15 = 0 or 
to 1111 if ALU bit 15 = 1 


Inhibit loading of A field 

and force B field to 1110 

if operand register bit 

01 = O or to 1111 if operand 
register bit 01 = 1 


Ail functions are inhibited 
if an 1/0 request is issued. 


Table 2-10. Register Field Selection 


Bits Selected From 
Instruction Register 


TS Field for register file 
000 03 02 01 00 
001 04 03 02 01 
610 05 04 03 02 
O11 06 05 04 03 
100 07 06 05 04 
101 08 07 06 05 
110 09 08 07 06 
111 10 09 08 07 


Other Controls 


Transfer instruction buffer to instruction register 
The contents of the instruction buffer will be transferred to 


the instruction register when TF and SF both equal zero, 
and GF has a low-order bit set to 1. 
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Control Fields 


AB MR TS WF 


Mask most 
Significant 
bit of BB field 


Mask most Selects 
significant field 
bit of AA field 


Enable Jump Signal 


A signal is sent to the memory-protection option designat- 
ing a jump instruction by setting the LB high-order bit to 
zero and the SC field to zero and the XF field equal to 11 or 
10. If the XF field equals 11, the interrupt flag will be reset. 


Reset Interrupt Flag 


The interrupt flag will be reset if the LB field equals 00 or 
Ol and the XF field equals 11 or Ol. When set, the 
interrupt flag prevents interrupts. 


Enable Special ALU Mode 


(This feature is useful for the standard instruction set, but 
not generally suggested) 


The ALU mode, carry input and overflow sampling may be 
forced according to the contents of the instruction register 
by setting the LA and LB fields equals to either 00 or 01 


(high-order bit equals zero) and the SH high-order bit 
equal to 1. In this case, the ALU function will be as follows: 


Bit 


3 As specified by FF field 


2 most significant 2 bits 
| Instruction register bit 7 
0 Instruction register bit 7 


complemented . 


2.7.2 Memory Addressing to 64K 


The standard instruction set has addressing capability to 
32K: words with 15-bit addresses. The use of bit 15 to 
select indirect addressing mode removes it from use as an 
address bit. The memory modules can recognize a 16-bit 
address which increases the range of addresses to 64K 
words. 


The most significant bit of the memory address bus is 
normally grounded to prevent any address generated by 
the standard instruction set from attempting to access 
above 32K words. This is necessary since the high-order bit 
can be set by indirect memory reference in the host 
instruction set. 


The WCS permits use of the full 16-bit addressing 
capabilities of a Varian 70 series system. This enabling is 
automatically inhibited while executing from page zero so 
standard 620 problems will execute correctly in the lower 
32K words of memory. 


User-written microprograms in the WCS can generate 16- 
bit addresses to cause access to the full 64K words. This 
mode is enabled or disabled with a group of control fields 
“in the microinstruction. Once enabled this mode is 
retained until explicitly disabled as described below or a 
system reset occurs. The enabled mode is not effective 
when page zero is active. 


64K Mode of Memory Addressing 


Enable Disable 

SF =0 SF=0 

TF=0 TF=0 
IM=1101 IM=1101 
{B=11 LB=11 

MF =1 CF =11 or 10 


Changing the memory mode requires all the 
conditions set as indicated. Figure 2-7 illus- 
trates memory bus control. 


2.7.3 Memory Bus Lockout Status 


Systems in which multiple processors share the use of 
common memory modules often require the capability of 
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SYSTEM RESET 


64K 
ADDRESSING 
DISABLED 


ENABLE 


64K 
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IF PAGE 0 


MICROPROG 
DISABLE 


(@)  ENABLE= IM= 1101A(T=0) A 
(S = 0) A (LB = 11) A(MF = 1) 


@) DISABLE = (IM= 1101)A (1 =O)A 
(S = O)A (LB = 11) A(C = 10V11) 


VTI1-1806 


Figure 2-7. Flowchart of Memory Address Control 


testing the contents of some memory locations and 
modifying those contents (if the results of the test indicate) 
without the possibility of another processor gaining access 
to that location between the test and the change. 


WCS Implementation 


The WCS permits use of a function allowing the processor it 
controls to temporarily lockout all memory modules 
connected to its memory bus. While the memory system is 
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locked out on one port, no accesses are permitted on the 
other port. To prevent simultaneous lockout from both 
processors the lockout mode for any memory bus only 
becomes enabled when the requesting bus actually gains 
access to the memory (so the other bus cannot establish 
the lockout mode). The memory lockout mode is set or 
reset with the following microinstruction fields: 


Set Reset 
Field LOCKOUT LOCKOUT 
SF 0 0 
TF 0 0 
IM 1101 1101 
LB 11 11 
CF X1 xo 
AA XXXO XXX1 


X indicates a bit position not involved in this operation. 


PROCESSOR 
A MEMORY 


PORT A 


If priority memory access (PMA) is present in the system, 
caution must be exercised to prevent the PMA from 
establishing its own lockout mode while either processor is 
in lockout mode. Simultaneous lockout would prevent all 
further accesses to memory and "lock-up" the system. 
Figure 2-8 illustrates memory bus lockout. 


Lockout is removed by system reset. 


2.7.4 Stack Use 


Three stack operations, branch/push, branch/pop and 

branch/delete are used on the microprogram-return stack. 
All are global and effect a page selection. On the branch/ 
push and branch/delete, the TS field gives the new page 
number. On the branch/pop, the word at the top of the 

stack gives the new page number. The return address 
which is pushed is an independent 13-bit specification 


PROCESSOR 
B 


PORT 8B 


MEMORY BUS LOCKOUT STATUS 


MEMORY CYCLES 
PERMITTED 


PROCESSOR A 
ACCESSES 
FOR TEST 


PROCESSOR A 
MODIFIES 


VTU1- 1808 


MEMORY CYCLES 
FORBIDDEN 


PROCESSOR A 
ACCESSES 
FOR TEST 


PROCESSOR B 
ACCESSES 
FOR TEST 


PROCESSOR A 
MODIFIES 


Figure 2-8. Memory Bus Lockout 
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provided by mask field of microinstruction from the 
destination of the branch. The 13-bit specification is made 
up from the following fields of the microinstruction: 


PAGE Word 
fe[u[ofe[e 7 ese arr 
All stack operations have a value of zero for the SF and TF 
fields, IM set to 1101 and LB set to 3. Push requires bit 1 
of the AA field set to 1. Pop is designated by bit 2 of the AA 
field set to 1 and bit O of the BB field set to 0. Branch/ 


delete is the same as branch/pop except bit 0 of the BB 
field is set to 1. 


TF SF IM LB AA BB 


Branch/push 0 0 D 3 bit 1 
= ] 
Branch/pop 0 0 D 3 bit2 bit O 
= ] = 0 
Branch/delete 0 0 D 3 bit 2 ~~ bit O 
= ] = ] 


In initializing the stack an error branch can be pushed into 
the first location. If a microinstruction tries to "pop" this 
return, an underfiow condition will occur and the error 
branch will be taken. An attempt to ‘push’ one more level 
than the sixteen allowed causes a branch to the address at 
Stack location zero. 


In addition to pop and push operations on the stack, a 
stack entry delete operation is provided. This causes a 
page branch to the address specified by the processor and 
deletes one entry from the top of the stack. 


All stack return addresses including the error return are 


restricted to the WCS. This avoids conflicts with processor- 
generated addresses during the pop operation. 


Questions and Answers About Microprogramming Stack 
Q: The WCS stack push and pop operations do not appear 
to be mutually —«clusive. If both are specified, would the 
stack first pop the new address then push the return 
address? 
A: Suchan operation is undefined and should be avoided. 


Q: Do micro stack operations proceed at full speed? 


A: The stack operates at the same speed as other writable 
control store operations -- 190 nanoseconds. 


2.7.5 Memory Addressing Using the 
Optional Memory Map 


The memory-map key register (used by VORTEX !I) cannot 
be easily modified from the WCS. As an option, the memory 
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map can be wired to operate with the processor key 
register. This mode is not supported by standard Varian 
software. The following paragraphs describe this special 
mode of operations. 


The processor key register is four bits which may be applied 
to the ALU input bus B as part of the status word. It is 
loaded from ALU output bus bits 12-15 and applied to the 
memory address bus as a four-bit extension to the 15-bit 
memory address register. The key register provides bits 15- 
18. 


key register Memory Address Register 
memory map input 
19 bits 


when 64K mode is enabled, bit 15 of the memory address 
register is also ORed into the effective map input bit 15. 


During memory cycles initiated by !/O (DMA), the 1/0 key 
register is applied instead. 


Care must be taken in using the processor key register as 
an input to the ALU input bus B. No 1/0 initiated memory 
bus activity must take place during application of the 
status word or the value of the 1/O key register may be 
used instead of the processor key register. 


2.7.6 Memory Protection 


if the memory protection is enabled, write operations are 
automatically inhibited. A memory-protection internal 
interrupt is generated as well as an |/O interrupt request. 
The memory-protection option may be disabled only by 
appropriate 1/O instructions, not by microinstructions. Care 
must be taken in using the memory protection if more 
than 32K words of memory are to be addressed (bit 15 of 
memory address ts enabled). Such use is very specialized 
and should only be undertaken after consultation with 
Varian Data Machines. 


2.7.7 Address Comparator Logic 

Address comparator logic is ;:ovided in V70 series 
processors to prevent erroneous operation in the eventa 
store instruction stores data into the next memory loca- 
tion in the program (macro). Erroneous operation would 
occur because the processor fetches the contents of the 
next memory location (n+ 1) before the execution of the 
current instruction (at location n) is completed. The 
comparator logic compares the address from the 
program counter with the address from the memory 
address lines. If the addresses are equal, the comparator 
logic generates an equal-address flag (MPLE) which 
enables the memory contents already fetched into the 
processor's instruction buffer to be updated to the new 
contents stored by the store instruction. 
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A store instruction can thus cause a dynamic alteration 
to the original program flow. An example where this dynamic 
alteration would be useful is in forming a BCS macroin- 
struction in which the address is located in the A register 
and the operation code is located in a memory location. 
The A register is combined with the memory location to 
produce the BCS macroinstruction. By using the STA in- 
struction with direct addressing into location n+1, the 
A-register contents are stored in location n+1 and are 
processed as the next instruction in the program. 


The following items should be considered when micropro- 
grams involving a store instruction are written: 


a. The instruction buffer is modified if the address in the 
program counter equals the address on the memory 
address lines and a non-memory accessing microin- 
struction is executed during the store operation (no 
back-to-back memory operations). 


b. The instruction buffer is modified if the address in the 
program counter equals the address on the memory 
address lines and either a memory accessing microin- 
struction or a wait-for-memory done condition follows 
the store operation (back-to-back memory operations). 
This type of operation is shown in the diagram below: 


Microinstruction 
being executed 


Previous micro- | Start memory | Memory-accessing 
microinstruction 


instruction for store 
operation 


Memory operation 
being pertormed 


Unknown 


‘ | 


J 
Program counter is equal to memory 
address here | 
| 


| 
1 
MPLE flag is generated due to equal 


addresses ; 


Program counter may no 
longer equal! the memory 
address, but MPLE flag 1s 
still active and the in- 
struction buffer is modi- 
fied anyway. 


c. If microprograms are written for a user-defined mac- 
roinstruction set and dynamic program alteration 
occurs, all store operations should be followed by a 
non-memory accessing microinstruction so that the 
MPLE flag can test for equal addresses. Any modifi- 
cation to the program counter during execution of the 
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store operation should be avoided. This type of opera- 
tion is shown in the diagram below: 


Microinstruction 
being executed 


Non-memory 
accessing 
micro- 
instruction 


Start memory 
for store op- 
eration 


Next 
microinstruction 


Memory operation 
being performed 


Store operation 


Unknown 


MPLE flag tests for equal 
addresses. 


2.7.8 MIRS Test 


If the shift counter bit 2 is true, then the MIRS test always 
sees a zero for MIR sign even when it is a one. This is 
implemented in the hardware to limit indirection to 4 levels 
in the 620 emulator ROM. 


2.8 QUESTIONS ABOUT 
MICROPROGRAMMING CAPABILITIES 


Q: If a current memory cycle is to alter the memory input 
register, and the memory input register is specified as 
the memory address source by the current microin- 
struction (awaiting memory cycle completion), are the 
old or new contents of the memory input register 
used for the next cycle’s address? Does the 
situation change if the memory input register is an 
ALU input and the ALU is selected as an address 
source? Does the WCS clock rate affect this? 


A: The new value of the memory input register is used 
when the memory input register is used as an address 
source. The memory input register should not be used 
through the ALU to determine the address of the next 
memory cycle when it can be altered by the current 
memory cycle. The WCS clock rate does not affect 
this. 


Q: What is the standard entry point to branch to when an 
interrupt is detected ? 


A: Interrupts, when enabled, cause a branch to the 
address specified by the AF field and interrupt address 
supplied by the 1/O control. Standard 1/0 interrupts 
supply an address component of 0111 to the least 


significant four bits. The most significant five bits are 
specified by the user (AF field) and may be anywhere 
in the currently active ‘control store page. At that 
address, the microprogram should perform the func- 
tions of the V73 IWAIT microinstruction (location OD7 
on page zero) and then branch to INT1 (ODI page 
zero) or perform in the current page the functions of 
INT1, INT2, INT3 and INT4. 


Q: Is data in the memory input register protected against 
DMA and PMA operations ? 


A: Yes, DMA and PMA operations do not alter the memory 
input register. , 


Q: When reading data from memory is the data available 


in the memory input register at a fixed number of 
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microinstructions following memory initiation, or 
must a wait for memory done be placed before using 
the data or starting another memory cycle ? 


: Data arrives in the memory input register no sooner 


than the second microinstruction after its initiation. It 
may arrive after that. The access time depends upon 
DMA or PMA or other memory bus cycles, semicon- 
ductor memory refresh cycles or core memory rewrite 
cycles in progress at the time. If a new memory cycle 
is to be initiated immediately following completion of 
the current cycle, interlocking is automatic as the 
execution of microinstructions will cease until the new 
cycle initiation is accepted by memory control. 
Otherwise a wait-for-memory-done function must be 
specified. 
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TECHNIQUES 


This section describes the use of flow diagrams in writing 
user microprograms and the interface with the 620 
emulation microprogram. Several detailed examples of flow 
diagrams for sample microprograms are included here. 
These examples will be continued in later sections, where 
the flow diagrams will be translated into assembly 
language. , 


3.1 INTERFACE WITH 620 EMULATION 


3.1.1 Execution of User Microprograms 


Branch to Control Store implementation 


The BCS instruction causes a branch to the WCS and 
always goes to page 1. The control store word in page 1 is 
specified in bits 0 - 4, allowing a branch to one of the first 
32 words, which contain vectors to microprogrammed 
routines. The BCS instruction is a special coding of an 1/0 
instruction and, as such, is not a generic mnemonic within 
the DAS assembler language. This instruction for use in 
symbolic DAS coding must be defined by the user. 


The BCS word tormat is: 


15 14 13 12 11 «4 
1 0 oO 0 1 


09 8 7 65 43 2 1 0 
0 QO pppxXxxXx x x x 


—_ 


where bits 0 through 4 specify the address in the CCS of 
WCS module 1: bits 5 through 7 (ppp) are available for 
programmers. 


The BCS macro is decoded directly on the WCS page during 
primary decoding time as defined by the processor logic. A 
BCS is performed only if decoder control store page 0 is 
currently selected. Any other control store selected causes 
the macro to be taken as part of a different instruction set. 
The BCS page branch does not change the decoder control 
store selection. A local page-branch micro-operation can 
change the selection of a decoder control store to page 1. 


The BCS instruction format is 
BCS: 0001000101 0aaabbbbb 
where aaa is the microprogram parameter (a 3-bit field) 


and bbbbb is the address on WCS page 1 manipulated 
upon entry to the contro! store. 


3.1.2 Steps in Instruction Execution 


The following are the general stages in the execution of a 
16-bit macro instruction: 


1. Amicroinstruction initiates an instruction fetch. 


2. The instruction is transferred from memory to the 
instruction buffer. 


3. The instruction is copied into the instruction register 
and a request is made for a decoding of the instruction 
buffer contents. This decoding simply identifies the 
instruction to be a member of a certain class of 
instructions and effectively causes a branch to a 
microroutine which does any work common to that 
class; for example, singie-word memory-addressing 
instructions may use the same microroutine for 
computing the effective memory address. 


4. Secondary decoding of the instruction determines its 
exact identity. This is done by such features as field. 
selection addressing, which allows using bits from the 
instruction register to determine a microprogram 
branch address. Using such methods, the microin. 
structions which complete the actual execution of the 
instruction are reached. 


5. Microinstructions which form the instruction are 
executed. 


3.1.3 Instruction Pipeline 


in V70 series computers, the term instruction pipelining 
refers to the technique of fetching the next instruction 
from memory before the current one has finished execut- 
ing. This is possible due to the availability of two 16-bit 
registers for holding instructions. The first is the instruc- 
tion buffer (IBR), which receives the instruction being 
fetched from memory. In IBR the next instruction is held 
while the current instruction being executed is in the in- 
struction register (1). When ready, the instruction buffer 
is transferred to the instruction register and the next in- 
struction may be fetched from memory. 


The chief advantage of this method lies in the fact that the 
microinstructions are much faster than the fetches from 
memory. 


Thus, without the pipeline, a one or two microinstruction 


delay would be added to the execution of each instruction 
while the processor waited for the instruction from memory. 
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Interfacing with the Pipeline 


The instruction pipeline is crucial to the execution of the 
standard instruction set. Thus, any new instructions being 
added through microprogramming must consider and be 
cautious of the effects and requirements of the pipeline. 
Because of the pipeline, user's microroutines in WCS can 
rely on certain things being true when they receive control 
from page zero. Likewise they must make sure certain 
techniques are used when they exit to read-only memory. 


Upon entry to WCS by a BCS instruction, the following 
conditions exists: 


a. The program counter (P) is pointing to the word 
following the BCS. 


b. The BCS command will be in the instruction register. 


c. The word following the BCS will be on its way from 
memory to the instruction buffer and memory input 
buffer. 


d. Inthe V70 through V74 series computers, registers 3 
and 5 are set to all zeros and all ones respectively. In 
the V75, V76 and V77-400 computers, registers B 
and C have these values. (See section 3.1.6.) 


On exit from WCS the microprogram must set conditions 
for the next command, and maintain the pipeline. In 
particular the following are required: 


a. Thenext instruction to be executed is in the instruction 
buffer. This will often be the word after the BCS, which 
was already on its way there on entry. If the BCS has 
a parameter, or if the instruction buffer was 
modified, then the instruction may have to be 
fetched. 


b. The program counter should be incremented to one 
beyond the location of the next instruction and an 
instruction fetch initiated. This will not only preserve 
the pipeline but will also make sure any memory 
activity necessary to complete setup of condition (a). 


c. The instruction buffer should be copied into the 
instruction register in preparation for its execution. 


d. A request for decoding of the instruction buffer 
contents should be made along with a page branch 
back to page zero, i.e., ROM. The decoding results in 
the correct microroutine getting control for execution 
of the next instruction. 


in most cases, the preceding steps can be summarized by 
the rule: 


The second to last microinstruction should 
increment P and do an instruction fetch. 


The last microinstruction should transfer IBR to 
| and request decoding addressing. 
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3.1.4 ROM Standard States 


Much of the interfacing with the pipeline can be done by 
using standard microinstructions (standard states) in 
page zero. These were developed explicitly for this purpose 
for use by the 620/f emulation. The most common ones 
make up the three microword sequence listed below. They 
may be used simply by doing a page jump directly to 
whichever microword is appropriate. 


Address Label Function 


13E SSIM Restarts the pipeline at P with 
an instruction fetch by P. It 


then branches to SS2M. 


92 S$S2M Maintains the pipeline by incre- 
menting P and requesting an 
instruction fetch. It branches 
to S$S3M. 

2D SS3M This instruction decodes the 


IBR contents to determine the 
next microinstruction to execute. 
It also copies the IBR into |. 


3.1.5 Summary of Branches Between WCS and 
ROM Control Store 


From ROM to WCS 
BCS Macro (from Decoder Page Zero Only) 


This macro ensures the start of a processor fetch during 
the primary decode of the BCS according to the V73 
pipeline rule. The clock change and page selection occur 
during the primary decoding of the microinstruction. 


1/0 Branch 


Control is transferred to the selected page of central 
control store during the data phase of the 1/O command. 
1/O branch can go to any central control store page and 
does not select a decoder. 


This mechanism assures that no DMA 1/O memory 
transfers and no processor. memory transfers are in 
process during the clock change. 


From WCS to ROM 


The 1/0 branch is not a viable mechanism from WCS to 
ROM. 


A micro level page branch is the standard method for going 
from WCS to ROM. This operation is the converse of the 
BCS disscussed above. 


Standard state sequences in the ROM provide pipeline 
Start up and various other housekeeping functions for the 
standard instruction set. These may be of interest for 
particular microprogramming entrances. 


3.1.6 V70 Series Register Usage 


The 620 emulation on V70 series systems uses some 
general purpose registers. Using the standard instruc- 
tions with his own microprograms a user is responsible 
for preserving the settings and restoring those necessary 
to their original conditions. The use and requirements for 
particular registers are described below. All others are 
only used by user’s microprograms. 


Registers 0, 1, and 2 are used for the emulation of the A, B, 
and X registers respectively. These need not be restored 
by user’s microprograms. 


Register 3 is forced to all zeros by the halt microprogram 
and used as a source of zeros by the standard instruction 
set. Its restoration is required. 


Register 4 is also used by the halt program and saves the 
contents of the instruction register. While the standard 
microprograms are running it is not used and therefore 
does not require resetting. 


Register 5 is a source of ones for the standard micropro- 
grams and must be reestablished as such by a user's 
microprogram. 


Registers E and F (15 and 16) are used as temporary 
storage for some standard instructions yet their use does 
not extend beyond the particular single instruction so 
these two do not need to return to a set value. 


Register Usage 
Standard Use 


Number V70-V74 


Standard Use 
V75, V76, V77-600 


0 A register A register 
1 B register B register 
2 X register X register 
3 All zeros* R3 

4 Saves | R4 

5 All ones* R5 

6 None R6 

7 None R7 

8-A None None 

B None All zeros** 
Cc None All ones** 
D-F None None 


*These registers must be restored before leaving. 
“*These registers are automatically restored by hardware. 


3.2 FLOW DIAGRAM 
3.2.1 Rationale 


As the reader should now be aware, the 64-bit microword is 
both extremely powerful and extremely complex. This may 
result in several problems. A beginning microprogrammer 
can be completely baffled how to start. Intermediate 
microprogrammers tend to be confused about how much 
or how little can be done in single microinstruction. 


The microprogram flow diagram is designed to minimize 
these problems. Making a flow diagram for a micropro- 
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gram is roughly comparable to the low-level flowcharting 
of an assembly language program. The flow diagram, 
however, is designed to provide special assistance to the 
microprogrammer. It gives the basic capabilities of the 
standard microword, thus providing reminders of both 
what can be done and what should be done in each 
*microword. 


3.2.2 Format 


A sample blank microprogram flow diagram form can be 
seen in figure 3-1. The vertical columns each represent a 
single microinstruction. 


The horizontal rows are divided into the type of operations 
that can be performed. A microinstruction is created by 
going down a column and _ filling in the appropriate boxes 
with the specitic operations desired in each general 
category. Many of these operations can be specified using 
the mnemonics introduced in the previous section. Table 
3-1 provides an ordered list of mnemonics. 


Specifically, the first row of the flow diagram is used for 
identifying the particular microword. Labeled IDENT, this 
row is usually left blank unless the microword 1s 
referenced elsewhere in the microprogram. Such reference 
occurs most often when the microword is the target of a 
jump from another microword. When not empty the box 
usually contains the label which will be carried through to 
the actual assembly language version. Depending upon the 
programmers preference absolute or relative addresses 
could also be assigned here. 


The group of three rows under MEMORY specifies both the 
current state of memory and the requests for memory 
operations being made in the current microword. The 
FUNCTION row specifies the former. It is useful for 
charting out memory activity and optimizing the memory 
usage. IN microprograms where memory activity is not 
critical, this row could be left blank. 


The REQUEST row indicates the type of memory request 
being made tn the microword. The ADDRESS row specifies 
the source of the memory address’ for the reques'ed 
operation. If no request is made, then both these rows can 
be blank. 


The ALU section of the flow diagram consists of four rows. 
These rows specify the two inputs for the ALU, the 
operation to be performed on them, and the destination of 
the result. 


Two rows are included in the STATUS section. The first, 
SAMPLE, specifies which flags and status bits are to be 
sampled during that microinstruction. Sampling is usually 
necessary before the flag or status indicators can be 

tested. The TEST row specifies which flag or status bit, if 
any, is being tested in the current microword. This testing 
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CIC eAt Figure 3-1. Sample Flow Diagram Form 
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.nay be used both for conditional memory requests and 
conditional addressing. 


The two rows of the ADDRESSING section specify the 
addressing method or mode being used and the resulting 
effective address or addresses. These boxes are often left 
blank to signify normal addressing with the next column 


on the right to be executed next. The labe! contained in the. 


IDENT row can also be used here. 


The SPECIAL ACTIONS section is provided for the micro- 
operations which do not fit conveniently into the other 
sections. Most common among these are the operations on 
the special registers and counters. These include the 
operand register, program counter, and shift counter. Such 
things as register field control or even general comments 
could also be included here. 
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The table also lists the corresponding assembler codes 
generated. Two formats are given: the first uses only the 
predefined assembler opcodes for the GEN or GMSK 
statements; the second is based on user-defined 
opcodes. (See Section 5.) 


3.3 FLOW DIAGRAM MNEMONICS 


Table 3-1 lists the sections of the flow diagram and some 
applicable mnemonics. These mnemonics represent the 
most common values and should be sufficient for many 
microprograms. Other functions without mnemonics 
can be described in whatever way the user finds clearest. 
The ways could range from actually writing the field 
values to putting in verbal commentary. 
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Flow Diagram 
Row 
LOCATION 


MEMORY 
FUNCTION 


MEMORY: 
REQUEST, 
ADDRESS 


ALU 
INPUT A 


Mnemonic 
None 


None 


IF,OVR 


IF,ALU 
IF,P 
1F,MIR 
OF,OVR 


OF,ALU 
OF,P 

OF MIR 
OS,OVR 


OS,ALU 
OS,P 
OS,MIR * 
BS,OVR 


BS,ALU 
BS,P 
BS,MIR 


Unconditional 


TESTT 
TESTF 
WAIT,MEMDN 


. Rn 


Rn,St 
Rn,SR 
Pp 

ZERO 
ONES 


Table 3-1. Flow Diagram Mnemonics and Microprogram Assembler Codes 


Format | 


IMO 


IM4 
IM8 
IMC 
IM1 


iM5 
Img 
IMD 
IM2 


IM6 
IMA 
IME 
IM3 


IM7 
IMB 
IMF 


SF1 (or SF2,TFO) 


SF3 (and not TFO) 
SF2 (and not TFO) 
SFO,IM1 


LAO,AAn 
LA2,AAn 
LA3,AAn 
LA1 

LAO,SH1 
LAO,SH2 


Format ll 


10(1FSOVR) 


TOUIFSALU) 
1O(1FSP) 
10(IF$MIR) 
10(O0FSOVR) 


10(OF$ALU) 
10(OF SP) 

10(OF$MIR) 
10(0S$OVR) 


10(O0S$ALU) 
10\OS$P) 

10(0S$MIR) 
10(BS$OVR) 


10(BS$ALU) 
10{(BS$P) 
10(BS$MIR) 


6(MEMC) or 
6(MEMC$),5(0) 


6(TESTT) 
6(TESTF) 
6(SPEC),10(WAITMD) 


12(A$GPR),24(Rn) 
12(A$GPRL),24(Rn) 
12(A$GPRR),24(Rn) 
12(A$P) 
12(A$SPEC),22(AZERO) 
12(A$SPEC),22(AONES) 


Comments 


User-supplied labels and addresses 


User-supplied commentary on memory operations 


Instruction fetch. Override memory operation of the previous microword using its 
memory address 

ALU output = memory address 

Program counter = memory address 

Memory input register = memory address 

Override memory operation of the previous microword using its 
memory address 

ALU output = memory address 

Program counter = memory address 

Memory input register = memory address 

Override memory operation of the previous microword using its 
memory address 

ma ALU output = memory address 

Program counter = memory address 

Memory input register = memory address 

Override memory operation of the previous microword using its 
memory address 

ALU output = memory address 

Program counter = memory address 

Memory input register = memory address 


Operand fetch. 


Byte store. 


oe 
oe 


Conditional request (on test condition true) 
Conditional request (on test condition false) 
Wait for memory done (before going to next microword) 


General register ‘n’ 

General register ‘n’ shifted left on bit position 
General register ‘n’ shifted right on bit position 
Program counter 

All zeros (0) 

All ones (F FFF) 


1) when using shifted general register user must specify high-low bits through SH 
field. 

2) when using the GMSK format, use 16(Rn) instead of 24(Rn) (or AKn instead 
of AAn). 
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Ze 


Flow Diagram 


Row 


ALU 
INPUT B 


ALU 
OUTPUT 


Mnemonic 


Ro 
MIR 
IOR 
STAT 
LIT,x 
MSK,x 


OPR 

ORSE 
OLSE 
ORZF 
ORLZ 


ZERO 
ONES 
TRNA 
TRNB 
INCA 
INCB* 
DECA 
DECB 
ADD 
SUB* 
SHFA 
AND 
OR 
EOR 
NOTA 
NOTB* 
TCB* 


Table 3-1. Flow Diagram Mnemonics and Microprogram Assembler Codes (continued) 


Format | 


LBO,BBn 
LB1,BB1 
LB1,BB2 
LB1,BB3 
LB3,MKy 
LB2,MKy 


LB1,BB0 
LB1,BB4 
LB1,BB5 
LB1,BB6 
LB1,BB7 


FF3,MF1 
FF3 
FFF,MF1 
FFAMF1 
CF3 
FF1,CF3 
FFF 
FF9 
FF9 
FF6,CF3 
FFC 
FFB,MF1 
FFI 
FF6,MF1 
FFO,MF1 
FFS.MF1 
FF2,CF3 


Format I] 


11(B$GPR),23(Rn) 
11(B$SPEC),23(MIR) 
11(BSSPEC),23(1IOR) 
11(BSSPEC),23(STAT) 
11(LIT),15{y) 
11(MSK),15(y) 


11(BSSPEC),23(0PR) 

11(BSSPEC),23(ORSE) 
11(B$SPEC),23(O0LSE) 
11(B$SPEC) 23(ORZF) 
11(B$SPEC),23(ORLZ) 


14(ZERO),15(LOG) 
14(ONES) 
14(TRNA),15(LOG) 
14(TRNB),150(LOG) 
14(NCA),16(CRY 1) 
14(NCB),16(CRY 1) 
14(DECA) 
14(DECB) 

14(ADD) 
14(SUB),16(CRY 1) 
14(SHFA) 
14(AND),15(LOG) 
14(OR) 
14(EOR),15(LOG) 
14(NOTA),15(LOG) 
14(NOTB),15(LOG) 
14(TCB),16(CRY 1) 


Comments 


General register ‘n’ 
Memory input register 
(/O register 
Status word 
A 16-bit value from 0 to FF FF 
Instruction register contents masked by y. 
(y is the one’s complement of the desired value.) 


NOTE: When using MSK or LIT, caution should be used to avoid field conflicts with 
other mnemonics. 


Operand register 

Operand register right byte, sign extended 

Operand register left byte, sign extended 

Operand register right byte, zeros in left byte. 

Operand register right byte in left byte position, zeros in right byte. 


All zeros (0) 

All ones (FFFF) 

A (transfer input A) 

B (transfer input B) 

A+1 

AVB + 1 (B+ 1 when A = 0) 
A-1 

A+B (B- 1 when A = FFFF) 
A+B 

A-B 

A+ A (shift A left one) 

AAB 

AVB 

AMB (exclusive OR) 

A 

B 

AVB + 1 (two’s complement B when A = 0) 


The mnemonics {NCB and TCB require input A to be ZERO. Mnemonic DECB 
requires input A to be ONES. 


*cannot be used when input B is MSK or LIT. 
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TION 


STATUS, 
SAMPLE 


STATUS, 
TEST 


Rn (n = 0.1.2,...,F) 
Special registers 


POUT 
SCOUT 
OPROUT 
IBR and MIR 


SHFT 
OVFL 
ALU 


OVFL 
1OSR 
SSW3 
SSW2 
SSW 
TFIR 
ALUO 
ALUS 
ALUC 
ALUZ 
SHFT 
MIRS 
SFTC 
GPRS 
NORM 
QUOS 


Table 3-1. Flow Diagram Mnemonics and Microprogram Assembler Codes (continued) 


Format | Format I! 
WR1,AAn 17(GPROUT),24(Rn) 
RF1- 13(POUT) 
RF2 13(SCOUT) 
RF3 -13(OPROUT) 
SFO,IM4 

VF1 19(S$SHFT) 
Reter to Table 2-7 

TFO,SFO,GF2 TFO,SFO,7(S$ALU) 
GFO FIOVFL) 
GF1 7(1IOSR) 

GF2 7(SSW3) 

GF3 7(SSW2) 

GF4 7(SSW1) 
GF5 {TFIR) 

GF6 7(ALUO) 
GF? 7(ALUS) 
GF8 7(ALUC) 
GF9 F(ALUZ) 
GFA 7(SHFT) 
GFB 7(MIRS) 
GFC 7(SFTC) 
GFD 7(GPRS) 
GFE 7(NORM) 
GFF 7(QUOS) 


Comments 


General register ‘n’ 

1) general register cannot be used here if input B was LIT or MSK. 

2) general registers used for both input A and destination must be the same 
general register. 


Load program counter with ALU output. 

Load shift counter with ALU output. 

Load operand register with ALU output. 

ALU output must be maintained for one more microinstruction cycle. 


Set shift flag. 


- Set overflow flag. 


Set ALU related flags (i.e., ALUO, ALUS, ALUC, and ALUZ). 
NOTE: TF field must also be set in test addressing. 


Overflow flag 

1/O sense response 

Sense switch three 

Sense switch two 

Sense switch one 

Test from instruction register 
ALU ones fiag 

ALU sign flag 

ALU carry flag 

ALU zeros flag 

Shift flag 

Memory input register sign 
Shift counter all ones flag (i.e., overflow) 
General register O sign 
Normalize flag 

Quotient flag 


NOTE: These are only a basic set of abbreviations, to be used alone or in combination. 
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Fiow Diagram 
Row 
ADDRESSING: 


MODE, 
ADDRESS 


SPECIAL 
ACTIONS 


Mnemonic 


blank 


FSEL 
INT 
PJMP ton: 


1) using stack 


2) without memory 


request 
3) with memory 
request 


POPJMP 


DECODE 
1) with IBR to | 


2) without IBR to ! 


TESTT 
TESTF 


INCP 

INCSC 
INCP,OPROUT 
SHFTOP,LFT 
SHFTOP,RGHT 


iBR tol 
with decode 
without decode 


PUSH,x 


POPDEL 


ROVFL 
SOVFL 


Table 3-1. Flow Diagram Mnemonics and Microprogram Assembler Codes (continued) 


Format | 


/* or 
/N (adr) 
/F (base), F Sx 


/N(base),TSn 


/N(word),TSn 
/N(word),TSn, 
SFO,TFO,IM3 
/N(word),GF4, 
SF2,TFO,TSn 


TFO,SFO,IMD, 
LB3,AA4,BB0 


TFO,SFO,GF5 
TFO,SFO,GF4 


/T(pass, fail), TF2 
/T(pass, fail), TF3 


RF4 
RF5 
RF7 
SC1,WFO 
SC1,WF1 


TFO,SFO,GF5 
TFO,SFO,GF1 


TFO,SFO,IMD, 
LB3,AK2,MKx 


TFO,SFO,IMD, 
BB1,AA4,LB3 


TFO,SF1,GF4* 
TFO,SF1,GF2* 


Format !1 


/* or 
/N (adr) 
/F(base,FSx 


/N(base),TSn 


/P(word + page) 

/P(word + page), 
10(PJMP),SFO,TFO 
/P{word + page), 
7(PJMP$),6(MEMC$),TFO 


10(STACK),24(POPJMP), 
LB3,TFO,SFO,BBO 


5(0),6(0),7(DECODS$) 
5(0),6(0),7(DECODE) 


/T(pass, fail), 5(TT) 
/Tipass, fail) 5(FT) 


13(INCP) 

13(INCSC) 

13(OPROUT + INCP) 
18(SHFTOP),20(LFT) 
18(SHFTOP),20(RGHT) 


TFO,SFO,7(DECOD$) 
TFO,SFO,7(IBRS$!) 


10{STACK),16(PUSH), 
15(x),LB3,TFO,SFO 


10(STACK),23(POPDEL), 
LB3,TFO,SFO,AA4 


F(ROVEL) 
7(SOVEFL) 


Comments 


Next microinstruction is at next sequential address. 
Next microinstruction is at (adr) 
Field select addressing 


Interrupt addressing: TS selects interrupts sampled. 


Page jump to page ‘n‘ 


Branch, pop stack to an address specified by the stack (subroutine return). 


Addressing by decoder control store 


Test addressing; pass if test condition true 


Test addressing; pass if condition false 


NOTE: the fail address must be even and must be greater than the pass address. 


High-order 4 bits must be same for both pass and fail addresses. 


Increment the program counter 

Increment the shift counter 

Does both. 

Shift operand register left one bit position 
Shift operand register right one bit position 


NOTE: high/tow bits must also be specified by user on these two operations. 
Transfer ineuedon buffer to instruction register. 

Push value x on the stack (requires PJMP addressing mode) 

Delete entry at top of stack (requires PIMP addressing mode) 

Reset overflow* 


Set overflow* 


*Must be used with unconditional memory request. 
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3.4 FLOW. DIAGRAM EXAMPLES 
The following examples are included: 

1. BCS Entry Point tnitialization 

2. Memory-to-Memory Block Move 

3. Reentrant Subroutine Call 


4. Fixed-point ADD to any of 16 general registers with 
direct addressing to 64K. 


5. Cyclic Redundancy Check (CRC) Generation. 


Each of the examples includes a description of the problem, 
a description of how it was handled, and a flow diagram. 
Later in this manual, the examples will be continued in the 
form of assembler listings of the code produced from each 
of the flow diagrams in section 5. 


3.4.1 BCS Entry Point Initialization 


This is essentially an example of making a micro subrou- 
tine which is simply a NOP. From the standpoint of being 
an example, it details how to reach WCS and then return 
to the macro level. From a functional standard point, it 
provides meaningful initialization for the 20 (hex) BCS 
entry: points in WCS. By loading this program before ail 
others, any unused BCS entry points will have meaningful 
contents (as opposed to possibly fatal random contents). 


Referring to the flow diagram, (figure 3-2) the thirty-two 
entry points are all initialized to the same microinstruc- 
tion. It is simply a page branch to a standard microword, 
SS2M, on page zero. This will result in a return to the 
macro level by maintaining the pipeline and returning 
control to the ROM central control store. 


3.4.2 Memory-to-Memory Block Move 


This microprogram is designed to move a block of n words 
from one area in memory to another. 


For purposes of this example, the microprogram is called by 
executing a BCS to word zero of WCS page one. It takes its 
arguments in the following format: 


A register (RO): 


to address 
B register (R1): from address 
X register (R2): block length 


When called, words are sequentially copied from their old 
location (from address) to their new position (to address). 
The number of words moved is equal to the block length. 


The following commentary describes how the microprogram 
operates. Refer to the flow diagram figure 3-3. 


3-10 


Word zero in page one is the entry point for the BCS 
instruction. It contains a branch to a microword labeled 
MBM, which may be on any WCS page. This is the actual 
beginning of block move and no further decoding of the 
BCS is done. 


The microprogram starts by setting up its parameters. The 
current program counter value is saved in R7. Next, the 
from address minus one is put in its place. Having it in the 
program counter will allow easier use of it as an address 
source for memory requests. The to address is also 
decremented. These addresses are decremented «cause 
they are incremented in the instructions which request 
the memory operations. 


After this initialization, a three microinstruction loop is 
entered which does the actual block move. The first 
microword, (MBMA), increments the from address in the 
program counter. It then requests that the word at that 
address be fetched from memory. It also puts the memory 
input register (MIR) onto the ALU output. Once the looping 
is begun, the MIR will contain the word just fetched from 
memory. Placing it on the ALU will cause it to be stored at 
the to address, since the previous micro in the loop 
requested a write of ALU output into memory. 


The second mircoword in the loop decrements the biock 
length in R2. The ALU output (i.e, the new value) is 
sampled for testing in the next microword. 


The next microword, the third and last in the loop, 
increments the to address in RO and tests the ALU sign 
flag. If it is off, then the block length has not yet become 
negative and the necessary number of words has not yet 
been moved. In this case, an operand store is requested 
using the to address as the destination. The next 
microword will have to specify the the value to be stored, 
so a loop is made back to MBMA which will do this. This 
loop also causes the next word to be fetched and the 
process continues until the block length goes negative. in 
that case the loop is exited and the extra memory fetch 
requested is simply forgotten. 


Microword MBMB restores the program counter to the 
address in R7 and starts a memory cycle to restore the 
pipeline. A branch is executed to standard state SS2M 
which increments the program counter and starts a second 
memory fetch to fill the instruction pipeline. Upon entering 
standard state SS3M, the macroinstruction is decoded and 
control is returned to the processor's central control store. 


3.4.3 Reentrant Subroutine Call and Return 


This example provides cali and return microprograms for 
reentrant subroutines. The subroutine call stores its return 
address in the X register (R2) and saves the original 
contents of X on a stack pointed to by the B register (R1). 


The subroutine return simply pops the stack back into the 
X register and branches back to the return address. 
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Figure 3-2. Flow Diagram for BCS Entry Point Initialization 


cle 


®AOW 42019 Asoway-03-Asowey 203 wes8eig MO}d *E-£ |unBl4 


6200 -LILA 


LOCATION 


storing fetching fetching 
data data data 


Dé 
jet) 
o 2 
oa 
-0o 


- |_| 
ve 
2 r 
ul 
= 
cate ae eS ich ia = aad 
= 


PJMP 


-| ADDRESS MBM 


F-MBMA (092) 


POUT INCP POUT 


S3NOINHDAL 


For purposes of this example, the subroutine call is 
executed by doing a BCS to word 1 of WCS page 1. The 
word following the BCS is taken as the effective address of 
the subroutine being called. The subroutine return is 
made by executing a BCS to word 2 of WCS page 1. 


The stack operations are performed in the following way. A 
push causes the B register to be decremented and the X 
register stored at the resulting address. A pop causes the 
X register to be loaded from the memory location pointed 
to by the B register followed by the B register being 
incremented. 


The following is a detailed description of the subroutine 
call. Refer to the flow diagram in figure 3-4. 


The first microinstruction of the routine is at the BCS entry 
point. On the memory-to-memory block move, this first 
microword of the program did nothing but branch to the 
actual microroutine. The only reason for not combining it 
with the next microinstruction was to clarify the relation- 
ship of the entry point and the rest of the program. In an 
actual application where execution time is critical, the 
microwords would have been combined. This is done on 
the subroutine call example. The first microword decre- 
ments the stack pointer (Rl) and begins saving the 
contents of R2 at the resulting address. It then does a 
page branch to the rest of the microroutine which could be 
on any WCS page. 


The second microword places R2 on the ALU so that it will 
be stored by the memory request in the first microword. 
R2 must be on the ALU for the entire duration of the write 
into memory. Since this could take a variable amount of 
time, (depending on the type of memory in the system), a 
request is made to wait for the memory-done signal. This 
means the next microword will not be executed until the 
write operation is complete and thus, R2 will stay on the 
ALU for the necessary time. 


The third microword saves the return address in R2. The 
program counter is currently pointing to the word after th 
BCS instruction. That word contains the effective address 
of the subroutine to be called. Thus, the return address is 
obtained simply by incrementing the program counter and 
then storing it in R2. This microword also begins the 
actual transfer to the subroutine to be called. This is done 
by restarting the pipeline at the address of the subroutine. 
That address is already in the MIR due to the fact it was 
the word after the BCS. 


The fourth microword sets the program counter to the 
second word in the subroutine call and requests it be 
fetched. This completes the restarting of the instruction 
pipeline and a return can be made to ROM control. This is 
done with a page jump to SS3M on page 0. Note that the 
fourth microword has performed all the functions of SS2M. 


The following is a detailed description of the subroutine 
return. Refer to the flow diagram in figure 3-5. 
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The first microword begins restarting the instruction 
pipeline at the return address. Also, the program counter is 
restored. 


The second microinstruction begins the fetch of the original 


: contents of R2 off the stack. 


The third microword increments the stack pointer to finish 
the pop of the stack. It also finishes the restart of the 
instruction pipeline by requesting another instruction 
fetch by the incremented program counter. 


The last microword restores the old contents of R2, which 
by now have been transferred from memory to the memory 
input register (MIR). Since the pipeline has now been 
restored, the microword can return to ROM using a page 
jump and with request for decoding addressing. The 
decode will generate the next address in page zero based 
on the next 'macro' instruction to be executed. 


Note that the second to fast microword performs the 
functions of SS2M and the fast microword performs the 
functions of SS3M. 


3.4.4 64K-Memory ADD to any of the 
General-Purpose Registers 


This example adds the contents of any location in 64K 
words of memory to the contents of any of the 16 general- 
purpose registers, RO, R1,....RF. The sum replaces the 
previous contents of the specified register. If overflow 

occurs, the overflow status bit will be set. The addressing 
mode for this example will be indexing by general register 
Rl. 


In execution the contents of LOC bit 8 - 15 specify a branch 
to control store (BCS) instruction. Bits 0 - 3 define the 
operation to the performed and the addressing mode to be 
used. Bits 4 - 7 specify the general register affected. 


With indexing the contents of all LOC + 1 are added to the 
contents of the register (Rl), and the 16-bit sum 1s used 
as the effective address of the operand. The overand Is 
fetched from memory and is added to the contents of the 
register specified by the LOC 4 - 7. 


A flow diagram follows as figure 3-6. 


The strategy used for the operation described above has 
the following steps: 


1. (AD1 or AD1IA) enter from decoding of BCS in page 
zero. Address fetch cycle has been initiated. Initiate 
next instruction fetch and increment P. 


2. Transfer contents of MIR (address value) to OPR to 
preserve against alteration by previously initiated 
instruction fetch. 


3. Perform indexing by adding contents of R1 to contents 
of OPR. Initiate operand fetch using ALU output as 


effective address. (continued) 
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4. Wait for completion of operand fetch by specifying next 
instruction fetch with incremented program counter 
and field select register specifications from instruc- 
tion bits 4 - 7 into AA field. Set BB field to select MIR. 


5. Add contents of MIR to contents of previously selected 
register and store sum in selected register. Sample 
overflow condition. Page jump to V73 page zero with 
decoding of instruction fetched by step 1. 


Execution Time Estimate 


Execution time depends upon the memory speed involved. 
With 330 nanoseconds semiconductor memory the pipeline 
is kept full. The number of microinstruction times from 
decoding to decoding is six. All of these are from writable 
control store. The execution time is therefore six times 190 
or 1140 nanoseconds. Since three memory cycles are 
involved, the effective three cycle time is 1140 divided by 3, 
or 380 nanoseconds. 


3.4.5 Cyclic Redundancy Check (CRC) Generation 


INSTRUCTION FORMAT 


15 987 43 0 


Pes] acre] 
Data Array Word Address 


may be tast 
byte 


The packed byte array at the specified address is scanned 
and the 16-bit cyclic redundancy check is performed. The 
16-bit CRC is left in the accumulator (A register or RO). If 
the accumulator is not cleared before entry, the accumula- 
tor's contents will be included in the CRC. 

The CRC polynomial word is x’ ° a ee ae canes 1, 
which is commonly used in binary synchronous 
communication. 


Since array size can be quite large, the instruction can be 
interrupted after service of every two bytes. When 
interrupt service is completed, the process of CRC 
generation is resumed and runs to completion (except as 
interrupted). The overflow flag is used to signal an 
interrupted instruction. If it is set, contents of the B and X 


TECHNIQUES 


registers are taken as data address and byte count 
respectively. 


RO, Rl and R2 (A, B and X) registers are used by this 
instruction. RO is the current CRC value. R1 is the current 
data array address. R2 is the current byte count value. RF 
contains the CRC polynomial (octal 100005). The overflow 
flag is used to designate an incomplete instruction. 


The calling sequence normally used would be: 


TZA (clear accumulator) 

ROF (reset overflow flag) 

BCS CRC 

Address (data array address) 

Byte count (number of bytes in array) 


Detailed Description of Procedure 


1. Enter from decoding of BCS in page 1. Address fetch 
cycle has been initiated. The overflow flag is used to 
designate an incomplete instruction, i.e., one which 
was interrupted before the entire byte array was 
scanned for CRC generation. If such an interrupt had 
occurred the current data array address and byte 
count in registers Rl and R2 should be used rather 
than the corresponding values used when the instruc- 
tion was initiated. A memory cycle to fetch the byte 
count is initiated conditionally. The overflow flag is 
tested for an “'off'’ condition. The 16-bit word 
representing the CRC polynomial is placed in OPR. If 
the overflow flag is off, the next step is step 2. If it is 
on, step IA is executed. 


2.  Thedata array address is copied from MIR into R1. 


3.  Thecontents of R1 is usec as an address (through the 
ALU) and the first pair of bytes is fetched. The overflow 
flag is set to indicate that the instruction is 
incomplete. 


4. The byte count is copied from MIR into R2. ALU status 
is sampled so that the byte count can be tested for zero 
in step 5. 


5. The shift counter is loaded with - 8 (the number of bits 
per data byte). The ALU zero status flag is tested to see 
if the byte count was zero. Execu.ion is suspended 
(by a "wait for memory done’’) until the two data 
bytes are fetched. if the ALU zero flag is off, the next 
step is 5A; otherwise, step 18 is next. 


5A. The CRC polynomial placed in OPR in step 1 is now 
placed in RF. 


6. The data bytes in MIR are copied into OPR. 
(continued) 
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10. 


10A. 


11. 


12. 


15B. 


16. 


3-18 


Steps 7, 8, 9, 10, 10A, and 11 constitute the iterative 
loop which accumulates the CRC for the left data byte. 
In step 7, RO (the CRC) is shifted one bit left and 
applied to the ALU input A while the shift counter is 
incremented. Bit 15 of RO is copied into the shift flag 
(DSB). Bit 15 of OPR is applied to ALU input A bit 
00. OPR is also shifted one bit left. The CRC 
polynomial in RF is applied to ALU input B. The 
exclusive OR is performed by the ALU and the result 
is placed into RO. The shift counter is tested to see if 
the eighth bit of the left byte has been processed. If it 
has, step 10 is executed next; if not, step 8 is next. 


The DSB flag is tested to see if a correction cycle is 
needed. (lf bit 15 of the old CRC was a zero, the 
exclusive OR operation of step 7 must be cancelled.) 
lf a correction cycle is necessary, step 9 is executed 
next; otherwise, the next bit of the data byte is 
processed by returning to step 7. 


This correction cycle exclusively ORs the CRC in RO with 
the polynomial in RF. The result is placed in RO. When 
this ts done the resulting CRC is that which would 
have been obtained if step 7 had not performed an 
exclusive OR. The next bit of the data byte is next 
processed by returning to step 7. 


This step is entered from step 7 after the last bit of the 
left data byte is processed. The DSB flag is tested to 
determine the need for a correction cycle. The byte 
count in R2 is decremented. The ALU status is 
sampled so that it can be tested for zero in step 11. If 
a correction cycle is necessary, step 10A is executed; 
otherwise, step 11 is next. 


This is a correction cycle identical to step 9. 


The shift counter is reinitialized to - 8 for processing 
the right data byte. The ALU zero status flag is tested to 
determine if the right byte should be processed. If 
ALUZ is not equal to one, the next step is 12; if ALUZ 
equals one, the next step is 18. 


This step is identical to step 7. The right data byte 
which has been shifted left in OPR is now processed. 


This step is identical to step 8. 
This step is identical to step 9. 
The operations of step 10 are performed. The DSB flag 


is tested as in step 10. If it is set, step 15B is next; 
otherwise, the correction cycle of step 15A is next. 


. This step is identical to step 10A. 


This step tests for interrupts. If an interrupt is 
present, step 20 is next; otherwise, step 16. 


The data array address pointer in R1 is incremented 
and used as an address for a fetch of the next operand 
byte pair, if the ALU zero flag is off (indicating the 
decremented byte count at step 25 was not zero). If 


17. 


1A. 


18. 


19. 


20. 


the byte count was not zero, step 17 is next; 
otherwise, step 18 is executed. 


The shift counter is initialized to- 8 and execution is 
suspended until the next pair of data bytes is fetched 
from memory. Step 6 is next. 


lf step 1 determines tne overflow flag to be set 
indicating an incomplete instruction, step 1A initiates 
the fetch of a data word froni1 memory using the 
contents of Rl as an address. Step 17 is executed 
next. 


lf step 16, 11, or 5 determines the byte count to be 
zero, step 18 resets the overflow flag to indicate 
completion of the instruction. The program counter is 
incremented and the net instruction fetch is 
initiated. 


A page jump to ROM (page zero) V73 standard state 
/SS2M, is executed. /SS2M will initiate another 
instruction fetch to fill the pipeline. 


If an interrupt was detected at step 15B, the interrupt 
status must again be tested by step 20. This is because 
interrupts can be overriden by DMA traps and must 
be checked twice to ensure that a trap has not 
eccurred which would abort the interrupt. The !/0O 
control is requested to perform an 1/O interrupt 
sequence. Decoding is inhibited since only the 
interrupt status is to be tested. If an interrupt is 
found, step 21 is next; otherwise, step 16 is next. 


208. The cycle is performed as in step 10A. 


21. 


22. 


23. 


24. 


lf an interrupt was found at step 20, the data array 
address in R1 is incremented and the ALU Zero flag is 
tested to determine if the byte count at step 15 was 
zero. If it was not zero, step 22 is next; otherwise, 
step 24 is executed. 


The program counter is reduced by 3 to point ta the 
BCS instruction. After completion of the interrupt 
routine this instruction will be refetched and the 
overfiow flag will be tested in step 1 to determine the 
need to initialize R1 and R2 from the instruction 
second and third words. 


Execution is suspended until the 1/0 control signals 
completion of the interrupt sequence, then a page jump 
to ROM standard interrupt state/INT2 is performed. 


If the byte count was zero, the overflow flag is reset 
and an_ instruction fetch is initiated with the 
incremented program counter value. 


CRC Generation Timing 


Execution time depends on memory speed and data array 
size. If no interrupts occur the timing consists of (a) 
initialization -- fetch of BCS, address and byte count and 
first byte pair. This involves one ROM decode cycle and 
WCS microinstructions 1, 2, 3, 4, 5, 5A, 11, and 6 all at 
190 nanoseconds (assuming a 330 nanoseconds main 
memory cycle). Initialization thus amounts to 1520 


TECHNIQUES 


nanoseconds. (b) CRC processing -- each byte takes 16 to 
24 steps with the average 20 plus steps 10, 11, 15, 15B 
and 16 all at 190 nanoseconds. Processing takes an 
average of 8550 nanoseconds for each byte pair. (c) 
cleanup involves steps 18 and 19 from WCS at 190 


» Nanoseconds, and the memory cycle of SS2M at 330 


nanoseconds. Clean up takes a maximum of 710 nanonec- 
onds. Altogether the timing for an array of N bytes 
averages (2230 + 1/2(N=— 2)) times 8550 nanoseconds. 


319 
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ENTER 
een ne TZA (OPTIONAL - SEE TEXT) 
(ADDRESS FETCH IS UNDERWAY) CALLING ROF (OPTIONAL-~ SEE TEXT) 


SEQUENCE 


BCS CRC 
DATA ARRAY ADDRESS 


000 
Ea BYTE COUNT 


START BYTE COUNT FETCH IF INCOMP 
FLAG IS OFF (OVERFLOW) 

INCREMENT P 

POLYNOMIAL TO OPR 

TEST INCOMPLETE FLAG (OVERFLOW) 


INITIAL SETUP 


DATA ARRAY BYTE 1 BYTE 2 
FORMAT BYTE 3 BYTE 4 


021 
ci nen BYTE N 
SAVE ADDRESS IN RI 


DURING EXECUTION 


RO (A REGISTER CONTAINS CRC 

RI (B REGISTER) CONTAINS THE CURRENT 
ADDRESS OF DATA 

R2 (X REGISTER) CONTAINS THE CURRENT 


FETCH DATA WORD BYTE COUNT 


020 


FETCH DATA 


WORD 


SET INCOMPLETE FLAG (OVERFLOW) 


SAVE BYTE COUNT IN R2 
SAMPLE ALU STATUS 


022 
INITIALIZE SHIFT COUNTER 
TEST ALU = 0 FLAG FOR ZERO BYTE CT Rr reese Ute cr aia 
WAIT MEMORY DONE CATE MEMORY DONE 


TRANSFER OPR 
TO RF 


ey TRANSFER DATA TO OPR 


ADDRESS STEP # 


$0. 2 
naa? Figure 3-7. Flowchart for Cyclic Redundancy Check Generation 


Microprogram (1 of 4) 
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SHIFT RO LEFT TO ALU A INPUT - 
SHIFT OPR LEFT 


RO(15) -—DSB 
OPR (15) ALU INPUT A BIT 00 PROCESS FIRST 
POLYNOMIAL (RF) TO ALU B INPUT BYTE 
EXCLUSIVE OR ALU INPUTS 

LOAD RO 

INCREMENT SHIFT COUNTER 

TEST SHIFT COUNT OVERFLOW 


sc DECREMENT BYTE COUNT (R2) 
OVERFLOW SAMPLE ALU STATUS 
=0 TEST DSB FLAG 


| o2e | 8 


TEST DSB FLAG 


ae 


INITIALIZE SHIFT COUNTER 
TEST ALU’ O FLAG FOR 
ZERO BYTE COUNT 


RO TO ALU A INPUT 
RF TO ALU B INPUT 
EXCLUSIVE OR ALU INPUTS 
LOAD RO 

(CORRECTION CYCLE) 


RO TO ALU A INPUT 
RF TO ALU B INPUT 
EXCLUSIVE OR ALU INPUTS 
LOAD RO 

(CORRECTION CYCLE) 


Y 


ee Figure 3-7. Flowchart for Cyclic Redundancy Check Generation 


Microprogram (2 of 4) 
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PROCESs 
SECOND 
BYTE 


DECREMENT BYTE COUNT 
SAMPLE ALU STATUS 
DSB FLAG TEST 

FNABLE INTERRUPTS 


sc 
OVERFLOW 
an) 


034] 13] 


TEST INTERRUPTS 


INCREMENT ADORESS (R1) 
FETCH DATA WORD IF ALU =0 
FLAG IS OFF 
TEST ALU + 0 FLAG (BYTE COUNT - 0) 


RESET OVERFLOW 
INCREMENT P 
FETCH NEXT INSTRUCTION 


PAGE JUMP TO ROM 


VTI2-401 ' 
Figure 3-7. Flowchart for Cyclic Redundancy Check Generation 
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Re INTERRUPT 


037 


ENABLE 


INTERRUPTS DISABLE DECODE 
START 1/O INT SEQUENCE 


INCREMENT ADDRESS (R1) 
TEST ALU = 0 FLAG (BYTE COUNT = 0) 


02D 02C 


RESET OVERFLOW P-3—» P 
INCREMENT P (RESET PROGRAM COUNTER TO 
INSTRUCTION FETCH START CAUSE REFETCH OF BCS) 


02F 


WAIT FOR I/O DONE 


036 


PAGE JUMP TO ROM 


‘INT 2 
(OFF) 


VTI-1803 Figure 3-7. Flowchart for Cyclic Redundancy Check Generation 


Microprogram (4 of 4) 
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EEOL-LILA 


MEMORY 


STATUS ALU 


ADDRESSING 


OTHER 


T-CRCIA 
F-CRC2 


INCP, 
@PROUT 


T-CRCI8 CRC7 
F-CRC5A 


SCQUT @PROUT 


SandINHO3L 


See 


(py JO Z) Ud}JZesQUEH YD 40 wWeITeIG MOj}4 ‘B-E euNdIy 


WEOT-LILA 


> 
« 
= 
Ww 
= — en a 
pS Ek $$} 
ee home a = noe ee ae 
OUTPUT EOR | | EOR FF6 TRNB 
DESTINATION RO RO R2 0 
SAMPLE SHFT ALU 


ALUZ 


«@ | MODE TESTT FSEL TESTT PJMP 
z MS = 2 
77) 
” 
3 | 
« | 
- 1 
2 | ADDRESS Ls cai CRCO CRC7 X’032 CRC11 T-CRC18 INT2 
F-CRC8 F-CRC12 (page 0, X’FF) 
SHFTOP.LFT 
0 +OPROO SCOUT 
OPR154ALUA 00 
INCSC 
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(p J0 €) uOnesUEeH DYNO 40 WesBeIQ MOj4 *g-E e4N3B)4 


OTHER ADDRESSING STATUS pte 


$EOT-HILA 


MEMORY 


SPECIAL 
ACTIONS 


RF RF R3 


T-CRC15__ 
F-CRC13 


SHFTOP,LFT 
0*@PROO 
@PR15+ALUAOO 
INCSC 


ENABLE 
INTERRUPTS 


SUPPRESS 
DEC @DE 


T-CRC18 
F-CRC17 
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TEST | ALUZ ! | 


MODE NORM PJMP NORM TESTT 


| 
| ' 

I 

ADDRESS CRC19 SS2M |  cRe16 _T-CRC24 
(PAGE 0, X'92) | | F-CRC22 | 


ENABLE 
INTERRUPTS : 
SPECIAL porey SUPPRESS WAIT [0 POUT 
ACTIONS eee DECODE DONE 
START 1 
INT. CYCLE 
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SECTION 4 


MICROPROGRAM DATA ASSEMBLER, 
MIDAS 


For execution the microprograms must be expressed in the 
internal machine language, yet during their development it 
is advantageous to express the program in a symbolic 
language which has more meaning to the person writing 
the program. This symbolic language is then translated into 
the executable machine language by the assembler. 
In addition MIDAS assembler provides 

* symbolic addressing 

* macro-definition capability 

* user-defined microword formats 

* user-defined opcodes 

« address field calculations 


* error detection 


* concordance listing with MOS or VORTEX using the 
concordance program CONC 


4.1 BASIC ELEMENTS 


The source language input to the assembier consists of a 
sequence of records. Each record contains 80 character 
positions. These characters are represented internally in 
standard 8-bit ASCII codes. The following paragraphs 
describe the content and format of the input to MIDAS. 


Characters 


The characters forming the symbolic source statements are 
described below. Characters not in this set can appear 
only in the comment field. 


Alphabetic: A through ¢ 
Numeric: 0 through 9 
Special / slash 
Characters: “ asterisk 

+ plus sign 

- minus sign 

space (blank) 
' apostrophe 


( left parenthesis 
) right parenthesis 


MIDAS statements are formed from the character set 
above. The comment field can contain valid 70/620 ASCII 
characters in addition to any from the MIDAS character 
set. Literals may be formed from any ASCII characters. 


Symbols 


The programmer may create symbols to be used for 
Statement labels or to define numeric values. A symbcl 
may contain one to six characters from the alphabetic or 
numeric subset. The first character of a symbol must be 
alphabetic. 


Examples of correctly formed symbols 
ABC4 INPUT1 SAVE4X P23456 


Symbols may also use the pound sign ( =) or dollar sign ($) 
character in any character position. 


Example 


ASB#C1 SRUN AS$TOP #FIVE 
Constants 


A constant is a self-defining term. Four types of constants 
are available: decimal integer, hexadecimal, octal and 
binary. 


A decimal constant is an unsigned sequence of decimal 
digits. The value of a decimal constant may not exceed 
32767. 


A hexadecimal constant is an unsigned sequence of 
hexadecimal! digits, base 16, preceded by the letter X and 
an apostrophe. The maximum hexadecimal number 
processed by the assembler is X'7FFF. 


An octal constant is an unsigned sequence of octal digits, 0 
through 7 -preceded by the letter O and an apostrophe. An 
octal constant can not exceed 0'77777. 


A binary constant is an unsigned sequence of ones and 
zeros preceded by the letter B and an apostrophe. Binary 
constants may be as large as 16 bits. 


Expressions 


An expression is a single term or a series of terms 
connected by the following operators. All are integer 
operators. 


+ Addition 

- Subtraction 

* Multiplication 

/ Division 
A term is a symbol, constant, or a special symbol, *, which 
denotes the program location counter. A term is associ- 
ated with a value inherent to the term in the case of a 
constant, or assigned by the assembler. 
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Multi-term expressions are evaluated from left to right. No 
parentheses are allowed. Expressions are reduced to a 
single value by the procedure below. 


1. Each term is given a value 


2. Multiplication and division are performed from left to 
right 


3. Addition and subtraction are performed left to right 


4. If an expression has a leading minus sign, the value is 
computed as though a zero term preceded the minus 
sign. A leading plus sign is ignored. 


5. The value resulting is right-justified in its generated 
resultant field. Unspecified leading bit positions 
contain zeros. 


Program Location ‘Counter 


fhe assembler maintains a program location counter which 
is automatically initialized to zero at the start of each 
assembly. As program statements are processed the 
assembler assigns consecutive memory (WCS) addresses to 

the microinstructions generated, unless the program 
location counter is explicitly modified. The counter may be 
modified by the ORG and ALOC directives. The asterisk (*) 
character as a Jabel denotes the current value of the 
program location counter. 


4.2 GENERAL FORM OF STATEMENTS 


Input to the assembler is in the form of statements in 
punched-card images. The statement is contained in a 
fixed format in character positions 1 through 72. 73 
through 80 are reserved for sequencing information and 
have no effect on the generated microprogram. 


A statement is divided into a label, operation, continuation, 
operand, and comment field. These are discussed in order 
below. 


Label 


A source statement can be associated with a symbolic 
label, which allows the statement to be referenced from 
other statements in the program. The label, if present, 
must begin in character position 1 and is terminated by a 
space. A label may be a one to six character symbol. 


Operation 


The operation field may consist of the format-defining 
operator FORM, the label of a predefined or user-defined 
format statement, a macro name or an assembler 


directive. The operation field begins in position 8 and is 
terminated by a space. 


Continuation 


Continuation lines may be used when additional lines of 
coding are required to complete a statement originating on 
one line. There can be up to three continuations per 
statement. This is designated by the character C in 
position 15. The actual statement continues in positions 16 
through 72. Continuation lines are only valid for the 
format and program statements. 


Operand 


The operand field begins in position 16 and is terminated 
by a space. The operand field may contain subfields 
separated by commas. A leading comma in the operand 
field is ignored. 


Comment 


The comment field is optional for documenting programs. 
The content of this field is output on the assembly listings 
but in no way has an effect upon the assembly process. 
The comment field begins with the first non-blank 
character following the operand field. 


4.3 STATEMENT DEFINITIONS 


MIDAS processes four types of statements: format. pro- 
gram, assembler-directive and comment. 


4.3.1 Format Statement 


The format statement labels and describes a structure for 
the microinstruction generated by the program statement. 
Each program statement specifies a format in which the 
user has grouped and broken’ up fields within the 
microword to set values. Two predefined formats are GEN 
and GMSK, ‘standard’ formats shown in figure 4-1. The 
user may define additional formats through the use of the 
format statement. 


The general form of the format statement begins with a 
required label followed by the word FORM followed by the 
field identifiers separated by commas. A field identifier 
consists of a field length in decimal, which may be followed 
by a hexadecimal constant enclosed in parentheses. 


label FORM field(1) , field(2), . . ., field(n) 
Where: 
label is a symbol formed according to 
the basic elements 
each field is a field identifier which is the 


field length in decimal. followed 

by an optional hexadecimal constant 

enclosed in parentheses 
length(constant) 


ordinal field 
field size - 
number name in bits 
1 TS 4 
2 AF/MS 9 
3 MT 1 
4 FS 4 
5 TF 2 
6 SF 2 
7 GF 4 
8 MR 1 
9 AB 2 
10 IM 4 
ll LB 2 GEN 
12 LA 2 
13 RF 3 
14 FF 4 
15 MF 1 
16 CF 2 
17 WR 1 
18 SC 1 (a) 
19 VF ] 
20 WF 1 
21 XF 2 
22 SH 3 
23 BB 4 
24 AA 4_] (b) 
(a) MK field in GMSK format 
(b) AK field in GMSK format 
ordinal field 
field size 
number name in bits 
1 TS 4 
2 AF/MS 9 
3 MT 1 
4 FS 4 
5 TF 2 
6 SF 2 
7 GF 4 
8 MR 1 GMSK 
9 AB 2 
10 IM 4 
11 LB 2 
12 LA 2 
13 RF 3 
14 FF 4 
15 MK 16 
16 AK 4 


Figure 4-1. Predefined Formats Recognized by MIDAS 


Field length can not exceed 16 bits. Fields are specified 
from left to right. Each field identifier has an implicit 
ordinal field number associated with it for reference. All 
64 bits of the microinstruction word must be allocated. 
Fields to which constant values have not been assigned are 
initialized to zero. 


Possible errors in the format statement include allocating 
more than or less than 64 bits and using a constant value 
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exceeding the size of the field. If an attempt is made to 
redefine a format, an error is indicated and the format is 
ignored. 


Continuation lines can be used on the format statement 


.’ but a field identifier may not be carried across lines. A 


comma must complete the field identifier before continuing 
the statement on the next line. If the last non-blank 
character of the operation field is a comma, it implies the 
next record will be a continuation. 


Example: 
LIST FORM 


14,4,2(X'3),2,4,1,2, 
C4,2,2,7,16(X'1FFF) ,4 


4.3.2 Program Statement 


The program statement represents the encoding of the 
microinstructions in symbolic notation. Each program 
statement references a format statement to be used in 
building the microinstruction. The format of the program 
statement is an optional label followed by a format label 
followed by a program field. 


label format program-field 
Where: 


the program-field consists of one or more of the following 
separated by commas. 


One address expression 
Predefined opcode 
User-defined opcode 
Field constant 


The single address expression specifies the mode of 
addressing to be used _ in fetching the next microsinstruc- 
tion. The address expression, if present, must be the first 
item in the program field. The format of an address 
expression is: 


/mode (expression, fail address) 


Where mode is a key denoting the following possible 
address modes: 


Normal addressing 
Test 

Field Select 

Test and field select 
Page jump 

implicit 


eVNTNAZ 


The value of the first expression in parentheses is the 
address of the next instruction under non-test conditions, 
or if the test passes. The value of the second expression is 
the address of the next instruction if the test faits. 


4.3 
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Modes N, F and P require only the first expression. T and S 
must use both expressions. None is given for the implicit 
mode. 


Address evaluation is performed with the following 
considerations: 


When the address mode uses field selection (modes F and 
S), the value of the expression must refer to the 
lower address selected in that field. This address 
must be an even numbered address. 


The contents of the mask field (MS) and the mask exten- 
sion field (MT), which provide the mask for the 
field address, must be defined by the user. 


In the test or the test-and-field-select modes of addressing, 
the fail address must be an even numbered word and 
must be greater than pass address taken modulo 16. 


For example, if the pass address is X'16, the range of the fail 
address must be from X'10 to X’1E and an even word. 
if the pass address is X'26, the fail address may 
range (on even words only) from X'20 to X’3E. 


The value is 13 bits with the high-order four bits specifing 
a page number and the low-order 9 a word within 
the page. 

The implicit mode generates normal addressing to the 
program location counter plus one. 

in a page jump the expression specified must produce a 
value which contains both the page and word 
addressing information. This destination can be 
defined through use of the EQU directive. 

If the test field (TS) is being used to select interrupts or 
to specify AA or BB field definition, its value must be 
defined by the user. 


Predefined Opcodes 


When a predefined opcode is used: in the program field, it 
specifies that a particular value be placed in a field of the 
microinstruction as defined by the format statement. 


Predefined opcodes are symbols consisting of three to six 
characters. The first two characters identify a field of the 
defined formats and the following characters specify the 
value in hexadecimal notation to be placed in the field. 


These field names must not be used as labels in user- 


defined opcodes. The two-character names for fields and 
the permissible range for each is given below. 


Predefined opcodes may be used with user-defined formats 
since each of these opcodes has an ordinal field number 
associated with it. There is no predefined opcode for the 
combined address field AF/MS. 
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Fields of the Microinstruction 


Ordinal 
Name Number Range 
TS 1 0-F 
MT 3 0-1 
FS 4 0-F 
TF 5 0-3 
SF 6 0-3 
GF 7 0-F 
MR 8 0-1 
AB 9 0-3 
IM 10 0-F 
LB 11 0-3 
LA 12 0-3 
RF 13 0-7 
FF 14 0-F 
MF 15 0-1 
MK 15 O - FFFF 
CF 16 0-3 
AK 16 0-F 
WR 17 0-1 
sc 18 0-1 
VF 19 0-1 
WF 20 0-1 
XF 21 0-3 
SH 22 0-7 
BB 23 0-F 
AA 24 0-F 


User-Defined Opcodes 


Users can assign values to symbols through the EQU 
directive. The opcode is placed in parentheses and 
preceded by the decimal ordinal field number designating 
the format field for the value. 


Statement labels and user-defined opcodes must avoid 
naming conflicts. 


Field Constant 


A field constant denotes a value to be placed in a 
microinstruction field. Either decimal, hexadecimal, octal 
or binary constant is placed in parentheses and preceded 
by a decimal ordinal field number. 


Error Conditions 


The effect of error conditions upon the continuing assembly 
depends upon the type of error. The errors listed below are 
indicated on the listing. The action shown in parentheses 
is taken in the program statement. 


a. Reference to a non-existent format (program statement 
is ignored) 7 


b. Value exceeds the size of field (value truncated) 
(continued) 


c. Both operand in the program field and a format 
constant are specified for the same field (inclusive OR 
of the values inserted) 


d. Multiple values generated for a field (first used) 


e. Inconsistency between the address mode specified and 
the values of the address control fields e.g., normal 
addressing and test field (TF) non-zero. (Mode is 
used to generate address) 


Additional Considerations 


The assembler evaluates each operand in the program 
field, and then uses the format indicated to form a 
microinstruction, Operand values and format _ field 
constants are placed in the appropriate fields. 


Values computed for a field are inserted in the field right- 
justified. Fields whose values are not explicitly defined in 
either the format or program statement are set to zero. 


A program statement may have continuation lines, but an 
operand may not be carried across lines. A comma must 
complete the operand before continuing the statement on 
the next line. If the last non-blank character of the 
operation field is a comma, it implies the next record will 
be a continuation line. 


Example: 


/N(EXC2),LB3,RF3,FFA, 
CMKF7FF 


EXC 1 GMSK 


4.3.3 Assembler Directives 


Instructions to the assembler are known as directives. 
These statements have label, operation, operand and 
comment fields. The operation field contains the name of 
the directive, such as EQU, ORG, ALOC, SPAC, EJEC, MAC 
and EMAC. 


The directives for macro definition MAC and EMAC are 
described in a later section. Other assembler directives are 
discussed in order below. 


EQU -- Equate 


The EQU directive is used to assign symbols to a given 
value or the value of another symbol. The symbol in the 
label field is required in this directive. It is defined to have 
the value of the expression in the operand field. 


The format of the EQU directive requires both a symbol in 
the label field and expression in the operand field. If the 
expression in the operand field contains a symbol, it must 
have been previously defined. 
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If the symbol in the label field has been previously defined 
or if there is no label, an error is indicated and the 
statement is ignored. 


Examples: 

THREE EQU 3 

SCZ EQU X'FE 

Vv EQU THREE+2 
ORG -- Origin 


The ORG directive sets the program location counter to the 
value of the expression in the operand field. 


A symbol in the label field is optional in the ORG directive. 
The expression to which the program location counter is 
set must be in the operand field. 


lf an expression in the operand field contains a symbol, it 
must have been previously defined. A negative value in 
the operand field causes an error to be indicated and the 
statement is ignored. A value of zero is acceptable. If the 
expression exceeds the page size, it is an error and 
causes the assembly to be terminated. 


At the beginning of each assembly pass the assembler 
initializes the program location counter to zero. 


Examples: 
ORG X' 1E0 
ORG BEGIN 


ALOC -- Allocate 


The ALOC directive informs the assembler that it is to skip 
over previously allocated locations as it is assigning 
sequential addresses to the generated microinstructions. 


From the beginning of an assembly pass until the 
occurrence of the ALOC directive the assembler will keep a 
list of all assigned locations. After the ALOC directive is 
processed the assembler will test each new program 

locaticri counter setting against the list of allocated 
locations. If a new value is in allocated space, the 
assembler will increment the counter and again make the 
test. The sequence will continue until unallocated space is 
found. 


It is recommended that during initia! program checkout an 
ALU directive with a value of zero be used at the start of all 
programs to get an output with NR, LC, and I/O errors. 


The format of the ALOC directive requires an expression in 
the operand field, but the symbol in the label field is 
optional. 
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An error is indicated and the statement ignored, if the 
operand field contains a negative value or exceeds the page 
size. 


in the implicit addressing mode the address of the next 
instruction is the next allocatable location. 


Examples: 
ALOC FIELD*4 
ALOC 0'20 
SPAC -- Space 


The SPAC directive provides a blank line on an assembly 
listing to improve readability. 


Both the label and operand fields of the SPAC directive are 
ignored. A symbolic source listing shows a blank line in 
place of SPAC directives. 


Examples: 

SPAC 

SPAC ADD HERE LATER 
EJEC -- Eject 


The EJEC directive causes the assembly listing device to 
advance to the first print location of the next output page. 


Both the label and operand fields are ignored. EJEC is 
listed. 


END -- End 


The END directive causes an assembly to be terminated. 
An END directive is required as the terminal source 
statement for each assembly. 


A symbol in the label field is optional and assigned the 


value of the program location counter. The operand field 
is ignored. 


4.3.4 Comment 


A statement with an asterisk in the first character position _ 


is entirely commentary. {ts contents have no effect upon 
the assembly process, however the statement is output to 
the listing. 


4.4 ASSEMBLY-LANGUAGE EXAMPLES 


The following examples show how representative microin- 
structions in the WCS could be coded as source statements 
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for MIDAS. 


Example 1: 
Exc 1 GMSK /N(EXC2),LB3,RP3, FPA, MKP7PF 


This example uses the normal mode of addressing. 


Example 2: 


/T(LASL2,LASL1),TP2,GFC,LA2, 
CRFS,WR1,SC1,XF3,SH6 


LASL1 GEN 


This example shows the use of the test mode of 
addressing, and the use of a continuation record. 


Example 3: 


BT10 GEN /P(BT20),2(X'F), FS4,RF4,XFI 

This example shows the use of the field select mode of 
addressing. The field address mask is provided by the 
hexadecimal field constant. 


Example 4: 


SWA22 GEN /S(LDA2,SWA26),2(X'C) .MT1,FSF, 


CTF3,GFB,LB1,RF3,FFA,MF1,5B1 


This example shows the use of the test and field select 
mode of addressing. The field address mask is provided by 
the hexadecimal field constant and the predefined opcode 
MT. 


Example 5: 


/*,1(B'1),IMF,LB1,FPFA,MF1,WRI, 
CXF1,AAE 


SEN2 GEN 


This example shows the use of the implicit mode of 
addressing. The instruction initiates 1/O activity and the 
binary field constant provides part of the !/O control store 
starting address. 


Example 6: 


P EQU x'200 PAGE ADDRESS (PAGE 1) 


GMSK /P(DIV+P),IMD,LB3, 
C15(#4+1+P),AK2 


This example shows the use of the branch/push operation. 
The operation effects a page selection and the destination 
and return addresses are global. The destination address 
is generated by the address expression. Note the page 
address contribution of P. The expression for field 15 
generates the global address which is pushed on the 
microprogram return stack. P contributes to this again. 


Control returns to the instruction immediately following 
the branch/push instruction in this example. 


Example 7: 


GEN IMD,LB3,AA4 


This example shows the use of the branch/pop operation. 
The global return address used is the last item pushed on 
the stack. 


Example 8: 


881M EQU X'13E 


GEN /P(SSiM),SPO,TFO,.IM3 


This example shows the use of the page jump mode of 
addressing. In page selection the value in the address 
expression must contain both the page and word 
contribution to the global address. In this example the page 
jump is to a standard state in the central control store 
(page 0) from some other page. 


Example 9: 


8S3M GMSK /N(SS2MI),1(X'E),GFS,IM6 

This example uses the normal mode of addressing but 
selects the decode-ROM and samples interrupts (GF fieid 
bit 2 is true). The hexadecimal constant defines the 
interrupts which are enabled. 


The following examples show the use of page branch, 
branch/push, and branch/pop operations. 


Example 10: 
$S2M EQU x'092 
MW1 GEN /P(SS2M) ,IM3,SFO,TFO 


This example of a microword, labeled MW1, does a page 
jump to one of the standard states in read-only memory. 


Example 11: 


PAGE EQU x'200 PAGE ONE SPECIFICATION 


/P(SUBR+PAGE) ,TFO,SFO, 


MW2 GMSK 
CIMD,LB3,AK2, 15(MW2+1+PAGE) 


SUBR GEN 


EXIT GEN TFO,SFO,IMD,LB3,AA4%, BBO 
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This example calls a micro subroutine and uses the stack 
to save the return address. The subroutine call is labeled 
MW2. It forms the return address by adding the word and 
page numbers, and then pushes the address on the stack. 
Likewise, the address of the subroutine is formed by adding 
page and word numbers. The subroutine returns by a 
microinstruction labeled EXIT which does a pop jump. 


4.5 MACRO CAPABILITY 


A macro provides a convenient way to generate a sequence 
of assembler source statements many times in one or more 
programs. The macro definition is written only once, and a 
single statement, the macro reference, is written each time 
the user wishes to generate the desired sequence of 
statements. These statements are then processed like any 
other assembler statements. Macro definition uses the 
MAC and EMAC directives. 


MAC -- Macro 


The MACRO directive introduces a macro definition. This 
definition is terminated by the EMAC DIRECTIVE. The 
name of the macro is the symbol which appears in the 
label field of the MAC directive. Operand field parameters 
may be passed from the macro-reference source statement 
to the macro through use of the special parameter symbols 
P(1) through P(n). 


A macro is invoked by the appearance of the macro name 
in the operation field of a statement. 


The label field must contain a symbol. 


In the macro-reference statement the operand field may 
contain a list of parameters. At the time the macro- 
reference is encountered. each parameter is evaluated and 
stored into a table within the assembler. The parameters 
may be labels, constants. or user-defined opcodes. Prede- 
fined opcodes are not permitted. The macro definition 1s 
then processed with the values in the table being 
substituted for the special symbols P(1) through P(n). For 
example, if the operand field of a macro-reference state. 
ment appears as: 


2,ABC,X'EO 


then within the generated macro the value of P(1) is 2, P(2) 
is the value of the symbol ABC, and the value P(3) is 224. 


All arguments in the macro-reference parameter list are 
evaluated prior to invoking the macro. 


An error is indicated and the MAC direction ignored, if the 
label field does not contain a symbol. Also an error is 
indicated and the reference is ignored if the macro has not 
been defined prior to its being referenced. 


If a symbol is present in the label field of a macro-reference 


statement, it is assigned the value of the program location 
counter at the time the macro is invoked. 
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A macro definition may contain a reference to another 
macro definition, nesting definitions. However, a macro 
may not be called recursively. 


EMAC -- End Macro 


The EMAC directive terminates a macro definition. The 
contents of both the label and operand fields are ignored. 


Example: 


The following example shows the use of macro definition 
and reference. 


ONE EQU 1 
TWO EQU 2 
THREE. EQU 3 
FOUR EQU 4 


SHFT MAC 
GEN /T(*,SS3M1),TF3,SF3, 
CGFC,IM8,12(P(1)),RF5, 
CWR1,22(P(2)),AA1 


ASLB SHFT 


TWO,FOUR 
LRLB SHFT TWO,ONE 
ASRB SHFT THREE, TWO. 


4.6 OPERATING INSTRUCTIONS 


This section describes the operating procedure for MIDAS 
in each of its three environments: VORTEX, MOS and as a 
standalone program. 


MIDAS runs under VORTEX as a level 0 background task 
and may be cataloged into the background library using 
the procedures described in the VORTEX Reference 
Manuals. 


MIDAS under MOS must be added to the system file using 
the system preparation Program as described in the 
Varian Master Operating System Reference Manual. 


MIDAS in the standalone environment makes use of the 
Standalone FORTRAN !V loader runtime !/O and runtime 
utility. Use of the components is described in the 
FORTRAN !V Reference Manual. 
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4.6.1 VORTEX Environment 


MIDAS is scheduled from the background library at level 0 
by the /LOAD,MIDAS directive. MIDAS terminates when 
the END statement is encountered, and exits to the 
executive. Only one source program can be assembled for 
each load of MIDAS. 


MIDAS inputs symbolic source statements from the 
processor Input device (Pl) and outputs these statements 
on the processor output device (PO). When the END 
statement is encountered, MIDAS rewinds the PO file and 
commences pass two. During pass two, it inputs source 
statements from the system scratch device (SS) and 
produces an assembly listing on the list output device 
(LO), and object records on the Binary Output device (BO). 


PO and SS devices not only must be the same physical 
device, but the same magnetic tape, drum or dise unit. If 
Pi! is assigned to a Rotating Memory ‘Device (RMD) 
partition, MIDAS assumes the source records are blocked 
three 40-word records per RMD 120-word physical record. 
However, if Pl is the same logical unit as the System Input 
Device (SI), and it is assigned to a RMD partition, MIDAS 
assumes the source records are not blocked but consist of 
one source record per RMD 120-word physical record. If BO 
is assigned to a RMD partition, the output is blocked two 
60-word object records per RMD 120-word physical reocrd. 
The assembier's table space may be expanded and 
consequently larger source programs assembled by use of 
the VORTEX /MEM directive. 


4.6.2 MOS Environment 


MIDAS is loaded from the system file by the system loader 
by means of the /ULOAD,MIDAS directive. 


It reads the source records from P! and outputs them to 
PO. Pass two source input is from SS. When the END 
statement is encountered on pass one, the SS file is 
repositioned and reread. During pass two, the output can 
be directed to BO for the object module and to LO for the 
assembly listing. When an END statement is encountered 
on pass two, control is returned to MOS. Therefore, it is 
necessary to reload MIDAS with another /ULOAD directive 
if multiple assemblies are desired. 


4.6.3 Stand-Alone Environment 


MIDAS is loaded by the 620 stand-along FORTRAN IV 
loader, along with the runtime 1/O and runtime utility. The 
description of this loading procedure and subsequent 
execution is described in the 620 FORTRAN IV Reference 
Manual, where MIDAS is substituted for the DAS MR 
Assembler. Upon execution, MIDAS will input source 
records from logical unit 3 (Pl), output source records for 
Pass two to logical unit 9 (PO), input pass two source 
records from logical unit 8 (SS), Output binarv object 
records to logical unit 2 (BO), and output assembly listing 
to logical unit 4 (LO). When the first assembly is 


completed, subsequent assemblies may be performed by 
restarting MIDAS at location 0541. 


4.7 ASSEMBLER INPUT AND OUTPUT 


The following section contains a description of the source 
records required for assembler input and the object 
records and listing produced by the assembler. 


Source Records 


The assembler input consists of a sequence of logical 
records containing 80 character positions. If a logical 
record contains more than 80 positions, only the first 80 
are input and the remainder are ignored. If a record 
contains less than 80 positions, blank characters are 
supplied by the assembler to fill 80 character positions. 


Only the first 72 are considered in the assembly process. 
Character positions 73 through 80 may be used as 
desired. 


Listing Format 


An assembly-listing page consists of 44 lines per page with 
each line containing no more than 120 characters. The 
lines per page count may be changed when running under 
an operating system. Each page contains the following: 


Page number and title line followed by a blank line 
Program listing containing two less than the current 
lines/page count 


At the end of an assembly a symbol table will be printed 
followed by a jine containing the message "mmmm 
ERRORS ASSEMBLY COMPLETE’ where mmmm is the 
accumulated error count expressed as a decimal number. 


The line format for the title line is a function of the 
environment in which MIDAS runs. The following descrip- 
tion pertains to the standalone and MOS versions, with the 
comments in parentheses referring to VORTEX. Beginning 
with the first character position the format is illustrated 
below. 


Object Code Records 


MIDAS produces object code which is input for the 
microsimulator and the microutility programs. Logical 
records of the object code are a fixed length of 60 words. 
Word 1 is the record control word. Word 2 contains an 
exclusive OR checksum of word 1 and the remaining words 
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of the record. Word 3 through 11 optionally contain a 
program identification block. Words 12 through the end of 
the record (or 3 through end of record if there is no 
program identification block) contain data fields. 


Record Control Word Format 


The format of the record control word is as follows: 


15 14 13 12 111098 
100 


76543210 
a li1be dddddddd 


where a ts 1 if the checksum is suppressed, b is 1 if not 
starting record, c is 1 when it is not the last record, and d 
is binary record number modulo 256. 


Program Identification Block 


This block appears in words 3 through 11 of the starting 
record of each program. Word 3 contains the highest value 
of the program counter during the assembly, words 4 
through 7 contain an eight-character ASCIl program 
identification, and words 8 through 11 contain an eight- 
character ASCI] program creation date. 


Data Field Format 


Data fields contain either one- or four-word entries. One- 
word entries are loader control words, and four-word 
entries consist of data words. 


The format of the loader control word is code in bits 13-15 
and an address/count in the jow-order 13 bits. A code of 
zero instructs the loader to ignore this entry. One is the 
code for setting the loading location counter to the value 
contained in bits 0 through 12. A value of two indicates 
the following microinstructions should be loaded. The 
number of microinstructions minus one is specified in bits 
1 through 12. 


Data Words 


Data words contain microinstructions. Each microinstruc- 
tion is comprised of four 16-bit words. Word 1 contains bits 
63 through 48 of the microinstruction while word 4 
contains bits 15 through O of the microinstruction. A 
microinstruction will not be carried across a logical record 
boundary. If insufficient space remains on a logical record 
for the four-word microinstruction, the remaining space 
will be ignored and the microinstruction started on the 
next logical record. 
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4.8 ASSEMBLY ERROR MESSAGES 


During assembly the symbolic statements are checked for 
syntactic errors. In addition, a condition may occur where 
the assembler is unable to determine the correct meaning 
of the symbolic source statements. 

Either case is indicated as an error and up to eight error 
codes will be output beneath the source statement 
incorrectly constructed. 

NR, LC and |0 errors terminate the assembly. 

Each error code with the exception of !0 is followed by a 
space and two decimal digits indicating the character 


position the assembler was scanning when the error was 
detected. 


The error codes and their meanings are listed below. 


Error 
Code Meaning 


AD _ Address expression or associated fields in error 
(see below) 


cc Continuation not expected 
CE Numeric conversion error 
DD __Iilegal redefinition of a symbol 
ER Syntax error 
_ EX An expression contained an illegal construction 
FN Field number inconsistent with format 
10 1/O error 


LC Program location counter setting exceeds the 
maximum WCS page size (512 words) 


MF Duplicate field reference 
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NR = No memory available for addition of an entry to 
assembler's tables 


NS  Nosymbol in the label field where required 
OP = Operation field undefined 


SE Symbol in label field has a value during pass 2 that 
is different from the value determined in pass 1 


SY Undefined symbol. A value of zero is assumed 


SZ A value too large for the size of a field, or the fields 
defined in a format statement do not equal 64 bits 


The AD error may occur under these circumstances: 


a. With the character pointer in, or at the end of, ar 
address expression: 


1. A test fail address is not on an even num- 
bered word. 


2. A field select origin address is not on an 
even boundary. 


3. The displacement between the test pass and 
the test fail addresses is too great. 


b. With the character pointer at the end of the 

operand field: 

1. Norma! addressing mode and the FS or MT 
or TF field is not equal to zero. 

2. Test addressing mode is used and the TF 
field is equal to zero. 

3. Field selection addressing is the mode and 
the FS field is equal to zero. 

4. Test and field selection addressing mode 
and either the FS or TF field equals to zero. 

5. Page-jump addressing mode and either the 
FS or TF field is not equal to zero. 


SECTION 5 
CODING FROM FLOW DIAGRAMS 


5.1 GENERAL 


This section details the conversion of flow diagrams, (as 
developed in section 3), into code which MIDAS accepts. 
As examples actual assembler listings of the sample 
microprograms discussed in section 3 are included. 


Flow diagram conversion is basically a matter of table- 
lookup. Tables are included in this section which fist the 
Standard mnemonics and the corresponding assembler 
code. 


Assembler code produced is given in two different 
formats. The first format produces code using only the 
predefined assembler opcodes for the GEN or GMSK 
statements. The second format is based around user- 
defined opcodes which follow the mnemonics developed 
thus far as closely as possible. As these are not prede- 
fined, some burden is placed on the user to include the 
necessary EQU directives (these EQUs are available 
from Sperry Univac as a software part). However, the 
resulting code is considerably more readable than that 
produced in the first format. 


Each column in the flow diagram will produce a single 
assembler program statement. This transformation can 
be performed as follows: 


1. Fill in the label field if necessary, this will often be from 
the LOCATION section. 


2. Choose either GEN or GMSK as format label. The latter, 
GMSK, is used only when the 16-bit literal/mask is 
needed. 


3. Derive the appropriate address expression 


4. For each of the standard mnemonics in the column, 
add the statements shown in the conversion tables. 


5. Replace any nonstandard mnemonics with appropriate 
field value assignments. 


In addition to this translation, other assembler directives 
must be included to set the location of the program in 
WCS. In doing this, addressing considerations must be 
taken into account. For example, in test addressing the 
failure branch must always be to an even location. 


The standard mnemonics, together with the assembler 
code which they generate, are listed in table 3-1. 


5.2 EXAMPLES OF MICROPROGRAMS IN 
ASSEMBLY. LANGUAGE 


The five examples flow diagrammed in Section 3 are 
encoded in this section. 


The example of 5.2.3 contains the assembler directives 
needed for the user-defined opcodes of Format II. This 
example is available as Part No. 92H1709-001A, which 
includes initialization of all BCS entry points. 
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5.2.1 BCS Entry Point Initialization 


Since physical addresses were assigned at the flow diagram 
level, the transformation was quite straightforward. Note 
that a standard deck of all the EQU statements was used 
though not all were needed. 


THIS IS INITIALIZATION FOR BCS ENTRY POINTS 


Woe Wh 
aenne 


7 = 

8 * THE FOLLOWING ARE SUPPLEMENTAL OPCODES 

9 * FOR USE WITH THE MICRO. ASSEMBLER 

10 * 

11 * 
0009 12 ADD EQU 9 
0008 13 ALUC EQU 8 
0006 114 ALUO EQU 6 
0007 #15 ALUS EQU 7 
0009 16 ALUZ EQU 9 
000B 17 AND EQU x'B 
0002 18 AONE EQU 2 
0001 19 AZERO EQU 1 
0000 20 AS$GPR EQU 0 
0002 21 A$GPRL EQU 2 
0003 22 AS$GPRR EQU 3 
0001 23 AS$P EQU 1 
0000 24 AS$SPEC EQU 0 
0007 25 BSSALU EQU 7 
OOOF 26 BSS$MIR EQU X'F 
0003 27 BS$OVR EQU 3 
000B 28 BS$P EQU x'B 
0000 29 BS$GPR EQU 0 
0001 30 BSSPEC EQU 1 
0003 31 CRY! EQU 3 
OO0F 32 DECA EQU X'F 
0009 33 ODECB EQU 9 
0004 34 DECODE EQU 4 
0005 35 DECOD$ EQU 5 
0006 36 EOR EQU 6 
0003 37 FT EQU 3 
0001 38 GPROUT EQU 1 
000D 39 GPRS EQU x'D 
0001 40 IBR$I EQU 1 
0004 41 IFSALU EQU 4 
Qoo0c 42 IFS$MIR EQU x'c 
0000 43 IFS$OVR EQU ie] 
0008 44 IFSP EQU 8 
0000 45 INCA EQU 0 
0001 46 INCB EQU 1 
0004 47 INCP EQU 4 
0005 48 %INCSC EQU 5 
0002 49 IOR EQU 2 
0001 SO IOSR EQU 1 
0006 51 KOUT EQU 6 
0000 52 LFT EQU 0 
0003 53 LIT EQU 3 
0001 54 LOG EQU 1 
0001 55 MEMC EQU 1 
0002 56 MEMCS$ EQU 2 
0001 %S7 MIR EQU 1 
000B S58 MIRS EQU X'B 
0002 59 MSK EQU 2 
OOOE 60 NORM EQU X'E 
0000 61 NOTA EQU 0 
0005 62 NOTB EQU 5 
0005 63 OFSALU EQU 5 
000D 64 OFS$MIR EQU x'D 
0001 65 OFSOVR EQU “1 
0009 66 OFS$P EQU -9 
0007 67 OL2ZF EQU 7 
0005 68 OLSE EQU 5 
0003 69 ONES EQU 3 
0000 70 OPR EQU 0 
0003 71 OPROUT EQU 3 
0001 72 OR EQU 1 
0004 73 ORSE EQU 4 
0006 74 ORZF EQU 6 
0006 75 OS$ALU EQU 6 
O0O0E 76 OS$MIR EQU X'E 
0002 77 OS$SOVR EQU 2 


(continued) 


0000 


0000 
0001 
0002 
0003 
0004 
0005 
0006 
0007 
0008 
0009 
000A 
000B 
000c 
000D 
O00E 
OOOF 
0010 
0011 
0012 
0013 
0014 
0015 
0016 
0017 
0018 
0019 
OOTA 
001B 
oo1c 
001D 


QO13E 
0092 
002D 


0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0499000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 
0490000180000000 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


FOLLOWING ARE ROM STANDARD STATE ADDRESSES 


EQU 
EQuU 
EQu 


ORG 


GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 


‘GEN 


GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 
GEN 


» 


my 


aA 
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X'13E RESTART PIPELINE @ P 

x'092 MAINTAIN PIPELINE 

X'02D DECODE NEXT INSTRUCTION (IN IBR) 
0 


/N(SS2M),10(PIMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10(PIMP), 
/N(SS2M),10(PIMP), 
/N(SS2M),10(PUMP), 
/N(SS2M),10(PJMP), 
/N(SS2M),10( PUMP), 
/N(SS2M),10( POMP), 
/N(SS2M),10( PUMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10(PIMP), 
/N(SS2M),10(PIMP), 
/N(SS2M),10( PUMP), 
/N(SS2M),10(PIMP), 
/N(SS2M),10(PIMP), 
7N(SS2M),10( PIMP), 
/N(SS2M),10(PJMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10( POMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10(POMP), 
/N(SS2M),10(PJMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10(PIMP), 
/N(SS2M),10( PIMP), 
/N(SS2M),10(POMP), 


RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
RETURN 
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O0O01E 0490000180000000 164 GEN /N(SS2M),10(PJMP),1(0) RETURN TO ROM 

OO1F 0490000180000000 165 GEN /N(SS2M),10(PIMP),1(0) RETURN TO ROM 
167 END 

SYMBOLS 

0000 A$GPR 0002 ASGPRL 0003 AS$GPRR 0001 ASP 0000 ASSPEC 

0009 ADD 0008 ALUC 0006 ALUO 0007 ALUS 0009 ALUZ 

000B AND 0002 AONE 0001 AZERO 0000 BSGPR 0001 BSSPEC 


0007 BS$ALU OOOF BS$MIR 0003 BSSOVR 0COOB BSSP 0003 CRY1 
000F DECA 0009 DECB 0005 DECODS 0004 DECODE 0006 EOR 
0003 FT 0001 GPROUT 000D GPRS 0001 IBR$SI 0004 IFSALU 
O000C IFS$MIR 0000 IFSOVR 0008 IFSP 0000 INCA 0001 INCB 
0004 INCP 0005 INCSC 0002 IOR 0001 IOSR 0006 KOUT 
0000 LFT 0003 LIT 0001 LOG 0001 MEMC 0002 MEMCS$ 
0001 MIR 000B MIRS 0002 MSK O000E NORM 0000 NOTA 
0005 NOTB 0005 OFSALU 000D OFS$MIR 0001 OFSOVR 0009 OFS$P 
0005 OLSE 0007 OLZ2F 0003 ONES 0000 OPR 0003 OPROUT 


0001 OR 0004 ORSE 0006 ORZF 0006 OS$ALU O00E OS$MIR 
0002 OS$OVR OO00A OS$P 0000 OVFL 0003 PUMP 0004 PIMP$ 
0001 POUT QOOF QUOS 0000 RO 0001 R1 0002 R2 
0003 R3 0004 R4 0005 RS 0006 R6 0007 R7 
0008 R8 0009 RI OOOA RA 000B RB 000Cc RC 
000D RD QOOOE RE OOOF RF 0001 RGHT 0002 S$ALU 


0006 S$OVFL 0001 S$SHFT 0002 SCOUT O000C SFTC 000C SHFA 

OOQOA SHFT 0001 SHFTOP 0000 SPEC O13E SS1M 0092 SS2M 

002D SSIM 0004 sswi 0003 SSW2 0002 SSW3 0003 STAT 

0006 SUB 0002 TCB 0002 TESTF 0003 TESTT 0005 TFIR 

QOOF TRNA Q00A TRNB 0002 TT 0001 WAITMD 0003 ZERO 
0 ERRORS ASSEMBLY COMPLETE 
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5.2.2 Memory-to-Memory Block Move 


The subroutine was assigned physical location 101, page 1 
as its first address. This places word MBMA on an even 
word, as it must be. Since the microroutine is on page 1, 
the need for the page jump from the BCS entry point no 
longer exists. It was included never the less. 


0001 


=~AOWON AU EWHND —- 


_— 


eee RRR HEHEHE HR 


MEMORY-TO-MEMORY BLOCK MOVE 
CALL: BCS TO WORD 0 
PARAMETERS: A REG - 'TO' ADDRESS 


B REG - ‘FROM’ ADDRESS 
X REG - BLOCK LENGTH 


EQU 1 


THE FOLLOWING ARE SUPPLEMENTAL OPCODES 


FOR USE WITH THE MICRO ASSEMBLER 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


=OWOKSLaAxXAmRWHUETOMRWAOKWK YOR WNOANMWONAHOO 
w 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


NWO aA KRUNUORN MON om WOMEN U ES 
wo 
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013E 
0092 
002D 


0000 


0000 1808000180000000 


0101 


0101 0810000008F90007 


0102 0818000000F10000 


MBM 


> 


i, 


- © © @ a 


IanO w yY 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


yaa 


2] 
re) 
c 
WeNKKUNWN BM ANNWNWEO mK RM RN KKK MK KO DIMM SWNOX A SWOKNKAD Sos WOW 
be, | 


FOLLOWING ARE ROM STANDARD STATE ADDRESSES 


EQU X'13B RESTART PIPELINE &@ P 

EQu x'092 MAINTAIN PIPELINE 

EQU x'02D DECODE NEXT INSTRUCTION (IN IBR) 
ORG Q 


FOLLOWING IS BCS ENTRY POINT 
GEN /N(MBM), 10( PIMP), 1(1) BRANCH TO BLOCK MOVE ROUTINE 


FOLLOWING IS ACTUAL BLOCK MOVE ROUTINE 
ORG x' 1401 


SAVE P IN R7 


GEN /@,12(ASP), 18(TRNA),15(LOG),17(GPROUT) ,28(R7) 


DECR 'TO' ADDR 


GEN 74*,12(ASGPR),29(RO), 14(DECA), 17(GPROUT) 


DECR 'FROM' ADDR ; PUT IT IN P 
(continued) 


CODING FROM FLOW DIAGRAMS 


0103 0820000001F00001 164 GEN /*,12(A$GPR),24(R1), 14(DECA) ,13( POUT) 
166 * 
167 * FIRST LOOP MICROWORD; STORE AT 'TO'; REQUEST FETCH OF INCR 'FROM' 
169 MBMA GEN /*, 10(OF$P),6(MEMC),11(B$SPEC),23(MIR),14(TRNB),15(LOG), 
0104 O8280404A4A80010 170 C13(INCP) 
172 * 7 
173 * SECOND LOOP MICROWORD; DECR BLOCK LENGTH; SAMPLE RESULT FOR TEST 
0105 OB30008000F10002 175 GEN /*,12(ASGPR),24(R2),14(DECA),17(GPROUT) ,7(S$ALU) 
177 * 
178 * FINAL LOOP MICROWORD; EXIT OR CONTINUE THE LOOP WITH REQUEST 
179 # FOR A STORE AT INCREMENTED 'TO' ADDR 
1817 GEN /T(MBMB,MBMA) ,5(TT), 10(OS$ALU) ,6(TESTF), 
0106 283829C300070000 182 C12(A$GPR),24(RO), 14( INCA), 16(CRY1),17(GPROUT) ,7(ALUS) 
184 »* 
185 * EXIT MICROWORD ; RESTORE P AND THE PIPELINE 
187 MBMB GEN /N(SS2M),7(PIMP$),1(0), 10(IFSALU) ,6(MEMC$) ,5(0), 
0107 0490090201F80007 188 C12(AS$GPR),24(R7),14(TRANA), 15(LOG) ,13( POUT) 
190 END 
SYMBOLS 
0000 A$GPR 0002 A$GPRL 0003 AS$GPRR 0001 ASP 0000 A$SPEC 
0009 ADD 0008 ALUC 0006 ALUO 0007 ALUS 0009 ALUZ 
O00B AND 0002 AONE 0001 AZERO 0000 BSGPR 0001 BS$SPEC 
0007 BS$ALU OOOF BS$MIR 0003 BSS$OVR O0O0OB BSS$P 0003 CRYt 
OOOF DECA 0009 DECB 0005 DECOD$ 0004 DECODE 0006 EOR 
0003 FT 0001 GPROUT 000D GPRS 0001 IBR$I 0004 IFS$ALU 
O00C IF$MIR 0000 IFSOVR 0008 IFSP 0000 INCA 0001 INCB 
0004 INCP 0005 INCSC 0002 IOR 0001 IOSR 0006 KOUT 
0000 LFT 0003 LIT 0001 LOG 0101 MBM 0104 MBMA 
0107 MBMB 0001 MEMC 0002 MEMC$ 0001 MIR 0O0B MIRS 
0002 MSK 0O0E NORM 0000 NOTA 0005 NOTB 0005 OFSALU 
O00D OFS$MIR 0001 OFSOVR 0009 OFS$P 0005 OLSE 0007 OLZF 
0003 ONES 0000 OPR 0003 OPROUT 0001 OR 0004 ORSE 
0006 ORZF 0006 OS$ALU O00E OS$MIR 0002 OS$OVR 000A OS$P 
0000 OVFL 0003 PUMP 0004 PIMP$ 0001 POUT OOOF QUOS 
0000 RO 0001 R1 0002 R2 0003 R3 0004 RY 
0005 RS 0006 R6 0007 R7 0008 RB8 0009 R9 
OOOA RA O000B RB 000C RC 000D RD OO00E RE 
OOOF RF 0001 RGHT 0002 S$ALU 0006 S$OVFL 0001 S$SHFT 
0002 SCOUT 000C SFTC 000C SHFA OOOA SHFT 0001 SHFTOP 
0000 SPEC 013E SS1M 0092 SS2M 002D SS3M 0004 ssw 
0003 ssw2 0002 ssw3 0003 STAT 0006 SUB 0002 TCB 
0002 TESTF 0003 TESTT 0005 TFIR OOOF TRNA 000A TRNB 
0002 TT 0001 WAITMD 0003 ZERO 


0 ERRORS ASSEMBLY COMPLETE 
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0009 
0008 
0006 
0007 
0009 
000B 
0002 
0001 
0000 
0002 
0003 
0001 
0000 
0007 
OOOF 
0003 
000B 
0000 
0001 
0003 
OOOoF 
0009 
0004 
0005 
0006 
0003 
0001 
000D 
0001 
0004 
000c 
0000 
0008 


- 0000 


0001 
0004 


0005 
0002 
0001 
0006 
0000 
0003 
0001 
0001 
0002 
0001 
0008 
0002 
O00E 
0000 
0005 
0005 
oo0D 
0001 
0009 
0007 
000s 
0003 


5.2.3 Reentrant Subroutine Call and Return 


These routines were assigned locations beginning at word 
110, page 1. As with the previous example, the page jumps 
are no longer necessary since the routines are on the same 
page as their BCS entry points. In this case they were 
simply coded using normal addressing. 


1 bd] 

2 * 

3 REENTRANT SUBROUTINE CALL AND RETURN 
y : 
5 * CALL: FOR SUBROUTINE CALL : BCS TO WORD 1 
6 * FOR SUBROUTINE RETURN: BCS TO WORD 2 
7 = 

8 « PARAMETERS: B REGISTER - STACK POINTER 
9 * 

10 * 

12 * 

130 (* THE FOLLOWING ARE SUPPLEMENTAL OPCODES 
4 8 FOR USE WITH THE MICRO ASSEMBLER 
15 * 

16 * 

17 ADD EQU 9 
18 ALUC  EQU 8 
19 ALUO  EQU 6 
20 ALUS  EQU 7 
21 ALUZ EQU 9 
22 AND EQU x'B 
23 AONE  EQU 2 
24 AZERO EQU 1 
25 A$GPR EQU 0 
26 A$GPRL EQU 2 
27 A$GPRR EQU 3 
28 ASP EQU 1: 
29 A$SPEC EQU 0 
30 BS$ALU EQU 7 
31 BSS$MIR EQU X'P 
32 BSSOVR EQU 3 
33 BS$P EQU X'B 
34 B$GPR EQU 0 
35 BS$SPEC EQU 1 
36 CRY! EQU 3 
37 DECA  EQU X'F 
38 DECB EQU 9 
39 DECODE EQU 4 
40 DECOD$ EQU 5 
41 EOR EQU 6 
42 FT EQU 3 
43 GPROUT EQU 1 
44 GPRS EQU x'D 
45 IBR$I EQU 1 
46 IFSALU EQU 4 
47 IFS$MIR EQU “°C 
48 IFS$OVR EQU 0 
49 IF$P EQU 8 
50 INCA £EQU 0 
51 INCB  EQU 1 
52 INCP EQU 4 
53  INCSC EQU 5 
54 IOR EQU 2 
55 IOSR  EQU 1 
56 KOUT EQU 6 
57 LPT EQU 0 
58 LIT EQU 3 
59 LOG EQU 1 
60 MEMC  EQU 1 
61 MEMC$ EQU 2.. 
62 MIR EQU 
63 MIRS EQU X'B 
64 MSK EQU 2 
65 NORM  EQU X'E 
66 NOTA EQU 0 
67 NOTB EQU 5 
68 OFSALU EQU 5 
69 OFS$MIR EQU X'D 
70 OF$OVR EQU 1 
71 OFSP  EQU 9 
72 OLZF EQU 7 
73° OLSE EQU 5 
74 ONES  EQU 3 


(continued) 


0003 128 


013E 133 
0092 134 
002D 135 


0001 141 


0001 0880040300F10001 147 


0110 153 


155 
156 


0110 O88B00008OF80002 158 


* 


* % 


LAB1 


CODING FROM FLOW DIAGRAMS 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


iy] 


> 


MEWN- OX HM CWOKNKXHAHE =A WO 
y 


EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 
EQU 


WIN XXUONWNBHONHAWNHW LOA KK KN WK KM MM KK ODN DM 
be | 


FOLLOWING ARE ROM STANUVARD STATE ADDRESSES 


EQU X'13E RESTART PIPELINE d P 
EQU x'092 MAINTAIN PIPELINE 
EQU x'02D DECODE NEXT INSTRUCTION (IN IBR) 


FOLLOWING IS CODE FOR SUBROUTINE CALL 

ORG 1 

BCS ENTRY POINT PUSHES OLD R2 ON STACK 

GEN /N(LAB1),10(OS$ALU) ,6(MEMC),12(ASGPR),24(R1),14(DECA), 
C17(GPROUT) 

REST OF ROUTINE 


ORG X'110 


WAIT ON STORE OF R2 


GEN /*,6(SPEC),10(WAITMD) ,12(ASGPR) ,24(R2),14(TRNA) ,15(LOG) 


(continued) 
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CODING FROM FLOW DIAGRAMS 


160 * 

161 * 

163 
0111 0890040608070002 164 

166 * 

167 * 

169 

170 
0112 0168090221160110 171 

173, * 

174 &* 

175 * 
0002 177 

179° & 

180 * 

182 
0002 O8A8040201F80002 183 

185 = * 

186 = * 

187 * 
0115 189 

191 * 

192 * 
0115 O8B0040280F80001 194 LAB2 

196 * 

197 * 

199 
0116 0888040404070001 200 

202 * 

203 * 

205 
0117 00000191A0A90012 206 

208 
SYMBOLS 
0000 A$GPR 0002 ASGPRL 0003 A$GPR 
0009 ADD 0008 ALUC 0006 ALUO 
000B AND 0002 AONE 0001 AZERO 
0007 BS$ALU OOOF BS$MIR 0003 BSS$OV 
OOOF DECA 0009 DECB 0005 DECOD 
0003 FT 0001 GPROUT O000D GPRS 
OO0C IFSMIR 0000 IF$OVR 0008 IFSP 
0004 INCP 0005 INCSC 0002 IOR 
0110 LAB! 0115 LAB2 0000 LFT 
0001 MEMC 0002 MEMC$ 0001 MIR 
Q00E NORM 0000 NOTA 0005 NOTB 
0001 OFSOVR 0009 OFSP 0005 OLSE 
0000 OPR 0003 OPROUT 0001 OR 
0006 OSSALU O00E OSSMIR 0002 OSSOV 
0003 PJMP 0004 PIMPS 0001 POUT 
0001 R1 0002 R2 0003 R3 
0006 R6 0007 R7 0008 R8 
OOO0B RB ooac RC 000D RD 
0001 RGHT 0002 S$SALU 0006 SSOVF 
000C SFTC 000C SHFA OOOA SHFT 
013E SS1M 0092 SS2M 002D SS3M 
0002 ssw3 0003 STAT 0006 SUB 
0003 TESTT 0005 TFIR OOOF TRNA 
0001 WAITMD 0003 ZERO 


QO ERRORS ASSEMBLY COMPLETE 
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PETCH FIRST INSTRUCTION OF SUBR ; STORE INCR P IN R2 


/*,10(IFSMIR) ,6(MEMC), 12(A$P),14( INCA), 16(CRY1), 
C17(GPROUT) ,24(R2) 


GEN 


FETCH SECOND INST OF SUBR; SET NEW P; BACK TO ROM 
/N(SS3M),7(PIMP$),1(0), 10(IF$ALU) ,6(MEMCS$),5(0), 
C12(A$SPEC) ,22(AZERO), 


CII(BSSPEC),23(MIR), 19(INCB), 16(CRY1),13( POUT) 


GEN 


FOLLOWING IS CODE FOR SUBROUTINE RETURN 


ORG 


BCS ENTRY POINT - BEGINS FETCH OF INST AT RETURN ADDRESS 


/N(LAB2), 10( IFSALU) ,6(MEMC),12(ASGPR),24(R2), 
C14(TRNA),15(LOG),13( POUT) 


GEN 


REST OF THE ROUTINE 


ORG x' 115 


FETCH OLD R2 VALUE FROM STACK 


GEN /*, 10(OFSALU) ,6(MEMC), 12(ASGPR),24(R1),14(TRNA), 15( LOG) 


FETCH SECOND INSTRUCTION AT RETURN ADDRESS ; INCR STK PTR 


GEN /*,10( IFSP) ,6(MEMC),12(ASGPR),24(R1), 14(C INCA), 16(CRY1), 
C17(GPROUT),13(INCP) 
RESTORE R2 ; BACK TO ROM 
GEN 10(PIMP),1(0),7(DECOD$),11(BSSPEC) ,23(MIR), 
C14(TRNB),15(LOG),17(GPROUT) ,24(R2) 
END 
R 0001 A$P 0000 A$SPEC 
0007 ALUS 0009 ALUZ 
0000 BSGPR 0001 BSSPEC 
R 000B BS$P 0003 CRY} 
$ 0004 DECODE 0006 EOR 
0001 IBR$I 0004 IFSALU 
0000 INCA 0001 INCB 
0001 IOSR 0006 KOUT 
0003 LIT 0001 LOG 
000B MIRS 0002 MSK 
0005 OFSALU 000D OFS$MIR 
0007 OL2F 0003 ONES 
0004 ORSE 0006 ORZF 
R OOOA OS$P 0000 OVFL 
OOOF QUOS 0000 RO 
G004 R& 0005 RS 
0009 R9 OOOA RA 
OOOE RE OOOF RF 
L 0001 S$SHFT 0002 SCOUT 
0001 SHFTOP 0000 SPEC 
0004 SSswi 0003 Ssw2 
0002 TCB 0002 TESTP 
000A TRNB 0002 TT 


0000 


0000 0100040404000000 


0010 


0010 0100040404000000 


0020 


0020 0108000023A80010 


0021 01100402A0900001 


0022. 4118043404000010 


0023 000003C1A0910000 


SYMBOLS 
0000 AD1 0010 ADIA 
0023 ADS5 


CODING FROM FLOW DIAGRAMS 


5.2.4 64K Add to General-Purpose Register 


1 ™*ADD TO ANY REGISTER FROM 64K MEMORY INDEX BY R1 

2 * 

3 ORG 0 - 

y ® , 

5 aD! GEN /N(AD2),SF1,IM&,RF4 

6 * 

7 ¥*THIS ENTRY USED FOR EVEN REGISTER ADDRESSES. 

8 *INITIATE ANOTHER INSTRUCTION FETCH USING INCREMENTED PROGRAM COUNTER. 
9 * 

10 ORG x'010 

11. * 

12 ADIA GEN /N(AD2),SF1,IM8,RF4 

130 

14 *THIS ENTRY USED FOR ODD REGISTER ADDRESSES. 

15 ™*INITIATE ANOTHER INSTRUCTION FETCH USING INCREMENTED PROGRAM COUNTER. 
16 * 

17 ORG X'020 

18» 

19 <AD2 GEN /*,LB1,RF3,FFA,MF1,BB1 
20 * : 
21 *TRANSFER MEMORY INPUT REGISTER TO OPERAND REGISTER TO PREVENT LOSS 
22 *DUE TO PREVIOUSLY INITIATED FETCH. THIS IS THE BASE ADDRESS. 
23 * 
24 AD3 GEN /*,SF1,IM5,LB1,LA0,FF9,AA1 
25 * 
26 *PERFORM INDEXING BY ADDING R1 TO OPERAND REGISTER. INITIATE OPERAND 
27 *FETCH USING ALU OUTPUT. 
28 * 
29 AD4& GEN /*,TS4,MR1,AB2,BB1,SF1,IM8,RF4 

30» 

31 *FIELD SELECT REGISTER SPECIFICATION FROM INSTRUCTION BITS 4-7 TO 
32 *A FIELD OF MICROINSTRUCTION. SET B FIELD TO SELECT MEMORY INPUT 
33 *REGISTER. INITIATE ANOTHER INSTRUCTION FETCH USING INCREMENTED 

34 *PROGRAM COUNTER. 

35 * 
36 ADS GEN /P(X'0000),LB1,LA0,FF9,GFF,WR1,IM3 
37 = : 
38 *ADD CONTENTS OF MEMORY INPUT REGISTER TO THAT OF PREVIOUSLY SELECTED 
39 *REGISTER AND STORE BACK THE SUM. PAGE BRANCH TO ZERO AND DECODE 
40 INSTRUCTION PREVIOUSLY FETCHED. OVERFLOW AND CONDITION CODES ARE 
41 ™*SAMPLED. TRANSFER INSTRUCTION BUFFER TO INSTRUCTION REGISTER. 

42 * 
43 END 

0020 AD2 0021 AD3 0022 AD4 


0 ERRORS ASSEMBLY COMPLETE 


CODING FROM FLOW DIAGRAMS 


5.2.5 Cyclic Redundancy Check Generation 


*THIS MICROPROGRAM COMPUTES THE CYCLIC REDUNDANCY CHECK WORD ON A 
*PACKED BYTE ARRAY USING THE POLYNOMIAL: 

* X**164X9"154X80241 

*ENTRY IS VIA A BCS TO LOCATION 0 OF PAGE 1 

*THE WORD FOLLOWING THE BCS IS THE DATA ARRAY ADDRESS 

*THE WORD FOLLOWING THE DATA ARRAY ADDRESS IS THE BYTE COUNT 

* 

*THE 16 BIT CRC IS LEFT IN RO 

*RO,R1,AND R2 ARE ALL USED BY THIS INSTRUCTION (A,B,X). RF IS ALSO USED. 
*RO IS THE CURRENT CRC 

*R1 IS THE CURRENT WORD ADDRESS OF THE DATA 

*R2 IS THE CURRENT BYTE COUNT 

13. *RF CONTAINS THE CRC POLYNOMIAL B'1000000000000101 

14 THE MICROPROGRAM MAY BE INTERRUPTED AFTER EVERY TWO BYTES ARE PROCESSED 
15 *IF THE OVERFLOW FLAG IS SET UPON ENTRY THE CURRENT VALUES OF R1 AND 

16 *R2 ARE USED INSTEAD OF THOSE SPECIFIED BY MEMORY CONTENTS. 

17. *THE ACCUMULATOR (RO) SHOULD BE CLEARED PRIOR TO ENTRY UNLESS CRC IS TO 

18 *BE ACCUMULATED WITH A PRIOR CRC VALUE. 


N-COWONAULEWN a= 


19° *® 
20 =* 
21 *TYPICAL ENTRY SEQUENCE IS: 
22 * T2ZA 
23. * ROF 
24 * DATA 0105000 
25 «. DATA ADDR 
26 * DATA COUNT 
27) 6 
28 * | 
29  ¥*CRC GENERATION 
30 =* 
0000 31 ORG x'0 
0000 O1083804E7A7FFAF 32 CRC!1 GMSK /T(CRC2,CRC1A),TF3,SF2,IM9,LB3,RF7,FPFA,MK7FFA,AKF 
33 * 


34 *ENTRY IS FROM DECODE OF THE BCS. THE ADDRESS FETCH HAS BEEN INITIATED. 
35 *OVERFLOW FLAG [IS TESTED TO DETERMINE IF INSTRUCTION WAS INTERRUPTED 

36 *FETCH OF BYTE COUNT IS INITIATED USING INCREMENTED PROGRAM COUNTER 

37 *THE POLYNOMIAL IS PLACED IN OPR 

38 *IF OVERFLOW IS ON GO TO CRCIA OTHERWISE CRC2 


39 «* 
0020 40 ORG x'020 
0020 0110040280A80010 41 CRCIA GEN /N(CRC17),SF1,IMS,FFA,BB1,MF! 
; 42 * 


43 *COME HERE IF OVERFLOW FLAG WAS ON WHEN INSTRUCTION WAS FETCHED 
44 *FETCH DATA BYTE PAIR 


45» 
0021 01989000020A90011 46 CRC2 GEN /N(CRC3),LB1,FFA,WR1,5B1,AA1,MF1 
47 * 
48 SAVE DATA ARRAY ADDRESS IN R1 (FROM MIR) 
49 * 
0022 01380000E2A00070 50 CRC17 GMSK /N(CRC6),IM1,LB3,RF2,FFA,MK0007 
51 * 


52 *SET SHIFT COUNTER TO -8 
53 *WAIT FOR MEMORY DONE FROM DATA FETCH 


S40 
0023 0120008020A90012 55 CRC4 GEN /*,GF2,LB1,FFA,BB1,MF1,AA2,WR} 
56 * 


57 *SAVE BYTE COUNT IN R2 
58 *SAMPLE ALU STATUS TO CHECK FOR ZERO BYTE COUNT 


59 * 
0024 31282240E2A00070 60 CRC5 GMSK /T(CRC18,CRC5SA) , TF2,GF9,IM1,L83,RF2,FFA,MK0007 
61 * 


62 *PUT -8 IN SHIFT COUNTER (8 BITS PER BYTE) 

63 *TEST ALU ZERO STATUS FLAG TO SEE IF BYTE COUNT WAS ZERO 
64 *WAIT FOR MEMORY DONE FROM DATA FETCH 

65 *IF BYTE COUNT WAS ZERO GO TO CRC18 OTHERWISE CRCSA 


66 *® 
0025 0158050404000000 67 CRC18 GEN /N(CRC19),SP1,GF4,IM8,RF4 
68 * 


69 *WHEN BYTE COUNT WENT TO ZERO RESET OVERFLOW TO INDICATE COMPLETION 
70 ¥*START NEXT INSTRUCTION FETCH USING INCREMENTED PROGRAM COUNTER 


0026 0138000020A9000P n CRCSA GEN /*,FFA,MF1,AAF,WR1,LB1 
7 cugvs POLYNOMIAL (IN OPR) TO RF 

0027 0150000023A80010 76 CRCE GEN /N(CRC7),LB1,RE3,FFA,BB1,MF! 
1 eTRANSPER DATA BYTES FROM MIR TO OPR 

0028 01500000006900F0 20 crce GEN /N(CRC7),FF6,MF1,WR1,5BF 


82 *THIS IS A CORRECTION CYCLE 
83 *RO TO ALU INPUT A ; 
(continued) 
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0029 


O0O2A 


002B 


002c 


002D 
002E 


002F 


0030 


0031 


0032 


0033 


0034 


0035 


0036 


0036 


0037 
0037 


0038 


0190808000610032 


714823001569DAFO 


0490090000000000 


0178000069900030 


0178050404000000 
4110800000000000 


01B80000100000000 


01900000006900F0 


6168224000070001 


D128224062A00070 


0118048280A80010 


4190800000000000 


41F08080006 10032 


07F8000180000000 


71FC012700000000 


01DODO00006900FO 


CODING FROM FLOW DIAGRAMS 


*RF TO ALU INPUT B 
*EXCLUSIVE OR ALU INPUTS TO RO 
* 


CRC10 GEN 2(X'032),MTO,FS2,GF2,FF6,MFO,AA2,BB3,WR! 

* 

“AFTER LAST BIT IS PROCESSED TEST DSB FLAG FOR A CORRECTION CYCLE 

*DECREMENT BYTE COUNT ‘ 

*SAMPLE ALU STATUS TO ALLOW CHECK FOR BYTE COUNT ZERO 

*IF CORRECTION CYCLE NECESSARY GO TO CRC10A OTHERWISE CRC11 

C4 

CRC7 GEN /T(CRC10,CRC8) ,TF2,GFC,LA2,RFS,FF6,MF1,WR1,SC1,VF1, 
CXF3,SH2,BBF 

* 

*SHIFT RO LEFT TO ALU INPUT A 

*SHIFT OPR LEFT 

*RO(15) TO SHIFT FLAG (DSB) 

*OPR(15) TO ALU INPUT A BIT 00 

*POLYNOMIAL (RF) TO ALU INPUT B 

*EXCLUSIVE OR ALU INPUTS TO RO 

*INCREMENT SHIFT COUNTER 

*TEST FOR SHIFT COUNTER OVERFLOW, IF OVERFLOW GO TO CRC8 OTHERWISE CRC10 

= 


CRC19 GEN /P(X'0092),SF2,GF4 

* 

*PAGE JUMP TO PAGE 0 LOC 060 (SS2M) 

= 

CRC22 GMSK /N(CRC23),LB3,LA1,RF1,FF9,MK0003 

* 

*SUBTRACT 4 FROM PROGRAM COUNTER TO CAUSE REFETCH OF THE BCS INSTRUCTION 
*AFTER INTERRUPT PROCESSING 

* 

CRC24 GEN /N(CRC23),SF1,GF4,IM8,RF4 

CRC8' GEN /F(CRC9) ,FS2,2(X'022) ,TS4 

* 

*TEST SHIFT (DSB) FLAG TO SEE IF CORRECTION CYCLE IS NEEDED. IF BIT 15 
*OF THE OLD CRC WAS A ZERO THE EXCLUSIVE OR PERFORMED AT CRC7 MUST 
*BE CANCELLED. IF DSB WAS 1 GO TO CRC? OTHERWISE CRC10 

* 

CRC23 GEN /N(CRC25),IM2 

" 

*WAIT FOR IO DONE 

C3 

CRC10A GEN /N(CRC11),FF6,MF1,WR1,BBF 


* 

*THIS IS CORRECTION CYCLE SIMILAR TO CRC8 

x 

CRC21 GEN /T(CRC24,CRC22) ,TF2,GF9,FFO,MFO,CF3,WR1,AA1 

* 

* INCREMENT DATA ARRAY ADDRESS (R1) 

*TEST ALU ZERO FLAG FOR ZERO BYTE COUNT IF ALU ZERO IS ON GO TO CRC24 
*OTHERWISE CRC22 

* 

CRC11 GMSK /T(CRC18,CRC12),TF2,GF9,LB3,RF2,FFA,MK0007 

= 

*PUT -8 INTO SHIFT COUNTER 

*TEST ALU ZERO STATUS FLAG TO SEE IF RIGHT BYTE SHOULD BE PROCESSED 
*IF SO GO TO CRC12 OTHERWISE CRC18 

* 

CRC3 GEN /N(CRC4),SF1,GF2,1M5,FFA,BB1,MF1 

= 

*USING R1 AS ADDRESS INITIATE FETCH CF TWO BYTES. 

*SET OVERFLOW FLAG TO INDICATE INCOMPLETE INSTRUCTION 

* 

CRC13 GEN /F(CRC14),FS2,2(X'032),TS4 

* 

*IDENTICAL TO CRC8 

= 

CRC15 GEN 1(X'G),2(X'O3E) ,MTO,FS2,GF2,FF6,MF0,AA2,BB3,WR1 

% 

*PERFORM OPERATIONS OF CRC10. IF DSB IS SET GO TO CRC1I5B OTHERWISE 
*CRCISA 

* 


ORG X'036 
CRC25 GEN /P(X'OOFF) ,IM3 
*PAGE JUMP TO PAGE 0 LOC OFF (INT2) 
x 
ORG X'037 
CRC20 GEN 2(CRC16),1(X'7),MT1,GF4,MR1,IME 


* 
*WHEN CRC15 DETECTS AN INTERRUPT CHECK IT AGAIN TO SEE IF IT WAS 
*OVERRIDEN BY A DMA TRAP. 

*START IO INTERRUPT SEQUENCE 

*IF INTERRUPT GO TO CRC21 OTHERWISE CRC16 

* 

CRC14 GEN /N(CRC12),FF6,MF1,WR1,BBF 


* 


(continued) 
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CODING FROM FLOW DIAGRAMS 


5-14 


003E 


OO3E 71F8010600000000 


OO3F 11282A4280070001 


003A 


OO3A 21A823001569DAF0 


003C 


003C O1FO00000006900F0 


SYMBOLS 
0000 CRC! 
0034 CRC13 
OO3F CRC16 
0021 CRC2 
002D CRC24 
0026 CRCSA 
0 ERRORS 


0029 
0038 
0022 
0037 
0036 
0027 


CRC10 
crci4 
CRC17 
CRC20 
CrC25 
CRC6 


170 *IDENTICAL TO CRCS 
171 * 
172 ORG X'03E 
173, * 
174 CRCiI5B GEN 1(X'7),2(X'O3F) ,GF4, IMC 
175 
176 *LOOK POR INTERRUPT 
177, *® 
178 * 
179 CRC16 GEN /T(CRC18,CRC17),TF2,SP2,GF9,IMS,FFO,CF3,AA1,WRI 
1800 —Co® 
181  *INCREMENT ARRAY ADDRESS (R1) 
182 ™*PETCH NEXT BYTE PAIR IF ALU ZERO FLAG IS OFF (BYTE COUNT NOT ZERO) 
183 *IF BYTE COUNT WAS ZERO GO TO CRC18 OTHERWISE CRC17 
184 &® 
185 ORG X'03A 
186 CRC12 GEN /T(CRC15,CRC13),TP2,GFC,LA2,RFS,FF6,MF1,WR1,SC1,XF3, 
187 CSH2,BS8F,VF1 
188 *® 
189 *IDENTICAL TO CRC7. THIS PROCESSES THE RIGHT BYTE OF DATA WHICH HAS 
190 *BEEN SHIFTED LEFT IN OPR 
191 * 
192 ORG X'03C 
193 CRC15A GEN /N(CRC15B),FF6,MF1,WR1, BBP 
194 * 
195 *IDENTICAL TO CRCIOA 
196 * 
197 ® 
198 END 
0030 CRCIOA 0032 CRCI1 003A CRC12 
0035 CRC1S 003C CRCISA 003E CRC15B 
0025 CRC18 002B CRC19 0020 CRCIA 
0031 CrRC21 G02C CRC2Z2 O002F CRC23 
0033 CRC3 0023 cRCA 0024 CRCS5 
002A CRC? O02E CRCB8 0028 CRC9 


ASSEMBLY COMPLETE 


SECTION 6 
MICROPROGRAM SIMULATOR, MICSIM 


The Microprogram Simulator (MICSIM) helps the user find 
and correct microprogram bugs. Any program develop- 
ment includes some time to verify that the program solves 
the problem. Testing may find that it does not. Running 
the microprogram simulator aids in both the discovery and 
correction of microprogram errors. 


When the microprogram is free of errors, the simulator can 
be used to determine the performance before the design is 
final, measure the efficiency of the technique and evaluate 
changes and extensions. 

MICSIM runs on all V70 series systems. Microprograms can 
also be simulated on 620 systems without WCS. The 


hardware requirements depend upon the operating system 
used. 


6.1 BASIC ELEMENTS 

In general this simulator provides the basic facilities for 
inputting, modifying and outputting the contents of the 
simulated control store, tracing, and address halt of the 
microinstructions. 


The fundamental! program blocks of the simulator are: 


a. Simulation control, which inputs the simulator com- 
mands and directs their execution. 


b. Simulator command execution, which represents 
the actual execution of the simulator commands. 


c. Microinstruction execution, which executes a 
microinstruction by simulating its effect. 


d. Simulation information accumulator and list output. 


The relationships of the basic program blocks are illus- 
trated in figure 6-1. 


Note: The 1/0 functions of the computer are not simulated. 


6.2 GENERAL FORM OF STATEMENTS 
The simulator processes three types of directives. All 
directives begin with a single letter indicating the type. 
The fotlowing types of actions are handled by the 
simulator: 

a. initialize simulator and storage 

b. change and examine storage 


c. trace, dump and control execution 


Table 6-1 summarizes the directives for quick reference; 
section 6.7 provides detailed description and examples. 


MICRO 
SIMULATION 
CONTROL 


SIMULATOR 
CONTROL 
EXECUTIVE 


INTERFACE 
PROGRAM 


OPERATING 
SYSTEM 


PERIPHERAL 
/O 


 VTHN-1810 


Figure 6-1. Microsimulator Control Flow 


Table 6-1. Summary ¢! Microprogram Simulator 
Directives 


A. Initialize Simulator and Storage 


| Initialize simulator 

Z Clear tables and registers 

Pn Select page n (o through 4) 

LC Load central control store (CCS) 


LDA Load decoder contro! store (DCS) A 
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LDB Load decoder control store (DCS) B 
MS Select PI as input device 


MR __ Select SI as input device 


Change and Examine Storage 


Ar Alter/Display register r, where r is 


ALU output 

Shift counter 

Instruction register 

Key register in data loop 
Memory input register 
Operand register 
Program counter 

Status register 


OUVOZR-O>Y 


ARn_Alter/Display general register n 
(O through F hexadecimal) 


AJn_ Alter/Display stack position n 
(O through F hexadecimal) 


Cm  Change/Display main memory word m 
ECn Change/Display CCS word n 


EDdn Change/Display DCS d (A or B) word n 


Trace, Dump and Control Execution 


D Dump complete CCS 


Dm Dump contents of CCS starting at CCS 
word m 


Dm,n Dump contents of CCS from word m to n 
D,n Dump from word zero to n 

TS Trace set 

TR ‘Trace reset 


TSn,m Trace from CCS word n to word m 


Bn Begin simulated execution at CCS word n | 


Hn,n_ Halt at CCS address(es) n 
$S Single step set 
SR Single step reset 


R Return to MOS or VORTEX; Halt in 
standalone 


Two methods of correcting typographical errors are availa- 
ble to the operator. An entire line can be deleted by 
typing the backslash character (shift/L). The backslash is 
output as a visual aid. A line feed and a carriage return 
are output to indicate that the line has been deleted. A 
character just entered can be deleted by typing the 
backarrow character. The backarrow character is printed 
on the Teletype page printer as a visual indicator of the 
deletion. As many backarrows as necessary can be entered; 
each deletes one character (but not beyond the beginning 
of the line). 


Each simulator directive is checked for syntax errors as the 
input is interpreted. When an error is detected by the 
simulator an error message is output to the Teletype page 
printer. The simulator then is ready to receive the corrected 
directive. 


6.3 STATEMENT DEFINITIONS 


In the following discussion of simulator dialog, simulator 
input will be in bold type. This will not appear during 
actual runs. 


All numeric values denoted in the following discussion of 
the simulator >directives are hexadecimal (0-F). Numeric 
values which are entered on SI are right justified with 
unspecified leading bit positions containing zeros. 


6.3.1 Select Input Media (M) 


The select input media directive is used to select the device 
from which simulator directives will be entered. Normal 
operation uses the SI device assigned at load time. Using 
this directive, the Pl device assigned at load time can be 
used as an alternate input device. 


The two formats of the directive are: 


MS Select PI as input device 
MR Select SI as input device 


6.3.2 Initialize Simulator (1 or Z) 


The initialize directive is used to initialize to zero the 
contents of the simulator registers, the test condition 
flags, CCS control buffer and the CCS word execution 
count table. Also, the single step option is reset, the trace 
option is set and the CCS address halt.is set to 200 hex. 
This directive is normally used at the beginning of each 
simulation run. The simulator CCS's are not initialized. 


The Z directive performs a subset of the | directive 
functions. With this directive the following are cleared: 


a. Allregisters 
b. All stack entry 


c. Allsimulation flags and condition codes 
Unlike the | command, the following are not cleared: 


a. CCS halt values 
b. Trace flag and limits 
c. Single step flag 
d. Execution limit 


e. Page value and limit 


The Z directive is normally used when a simulation run is 
continued after an incorrect branch. 


6.3.3 Page Select (P) 


This directive is used to select the contro! store page upon 
which the simulator directive will be executed. Initializa- 
tion selects page 0. Once a page is selected, all directives 
will refer to that page unti! it is change by a new P 
command or until the system is reinitialized. The format 
for this command is: 


Pn where n = O, 1, 2, or 3. 


6.3.4 Load Control Store (L) 


This command is used to read the micro assembler output. 
assemble the data into usable 64-bit (CCS) words or 16-bit 
(DCS) words and store the words into the simulator control 
store. 


The format for this command is: 


LC -- Load Central Control Store (CCS) 
LDA -- Load Decoder A Control Store (DCS) 
LOB -- Load Decoder B Control Store (DCS) 
LM -- Load Main Memory 


The statement LOAD COMPLETE will be output to the 
Teletype following successful loading of the control store. 


6.3.5 Alter/Display Simulator Registers (A) 


This directive is used to display and change, or display 
only, the contents of general registers, stack positions and 
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any of the following simulator registers: 


Program Counter (P) 
instruction Buffer Register () 
Status Register (S) 
Operand Register (O) 
Shift Counter (C) 
Memory Latch (M) 
Processor Key Register (K) 
ALU Output (A) 


a. The format for display or change of the registers above 
in this directive is: 


nnnn(c/r 
ar insta 
mmmm Wherec = ‘ 
c 1 
(c/r) 


Where r is one of the register jetters above and ¢ is a 
comma, carriage return, a value followed by a comma or a 
value. mmmm is the contents of that register (output by 
the simulator) and nnnn is the desired contents. If the 
command is terminated with a comma (,), the simulator 
will output the letter A (signifying you are still in this 
routine) and wait for another register designator. If the 
directive is terminated with a carriage return (c/r), the 
simulator returns to the executive. If no change value is 
input, the contents remain the same. 


For the file registers and jump stack, the specific file 
register or stack position must also be designated upon 


initial entry. 


b. For general-purpose registers 


Where i is a hexadecimal number 0 through F designating 
the specific register and c is a comma, carriage return, a 
value or a value followed by a comma. 


c. For stack positions 


Where n is a stack position and c is a comma, carriage 
return, a value or a value followed by a comma. 


The rest of the format is identical to that for the other 


registers except that the comma terminator causes the 
display of the number and contents of the next sequential 
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file register or stack position. A comma terminator to 
register or stack position F effects a return to the simulator 
executive. 


Example 1: 
AP Display Program Counter 
0776 

No change, stay in command 
AM Display Memory Latch 
14FC 
(c/r) No change, return 
Example 2: 
AS Display Status Word 
0000 
FFFF Change Status to All Ones 
Example 3: 
ARA Display General register 10 
FFFF 
0000, Change to all zeros 
B Display general register 11 
1234 
(c/r) No change, return 


6.3.6 Change/Display Memory (C) 


This directive is used to display or display and change a 
memory location. Both the location and its contents are in 
hexadecimal notation. 


The format of the command is: 


Cmmmm 
hhhh 
c 


Where ¢ is as defined above and mmmm is the hexadecimal 
address of the memory location, hhhh is the contents of 
that word output by the simulator. If the simulator 
directive is terminated with a comma, the simulator will 

display the contents of the next memory location. If the 
simulator directive is terminated with a carriage return, 
the change/display memory directive is terminated. If no 
change value is input, the contents remain the same. 


6.3.7 Change/Display CCS Word (EC) 


The change/display CCS word simulator directive is used to 
display and/or change the contents of a CCS word. 


The format for the change/display CCS word simulator 
directive is: 
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nannnnnAnannnnann 
nAnnnAnAnnnAnaAnHNA, 
ECmmmm = 
hhhhhhhhhhhhhhhh Where b = {7 fraaw....ferrvin fev 
b 


(c/r) 


Where mmmm is the (hexadecimal) address of a CCS wui 

hhhhbhhhhhhhhhhh is the contents of that CCS wora 
(output by the simulator) and nnnnnnnnnnnnnnnn is the 
desired contents of that CCS word. If the simulator 
directive is terminated with a comma, the simulator will 
display the contents of the next CCS word. If the simulator 
directive is terminated with a carriage return (c/r), the 
change/display CCS word simulator directive is terminated. 
If no change value is input, the contents remain the same. 


\f the first character is a + or =, the remainder of the 
record is treated as a field change only. The + is used to 
change only the fields specified. The = is used to clear the 
microword before changing the fields specified. f(n) is a 
2-character field name and v(n) is the change value. 


If less than 16 digits are input for a change, the digits are 
right justified and zeros will appear in the most significant 
bits not specified. 


Example 1 


EC8A 
0123456789ABCDEF 
FEDCBA9876543210 


Example 2: 


ECDC 
FFFFFFFFFFFFFFFF 


DD 
AAAAAAAAAAAAAAAA 
¢) 


Example 3: 


In word F, change only the TS and AA fields; in word 10, 
change fields TS, MS, and LB and clear all the others. 


ECF 
0123456789ABCDEF 
+ TS4,AAF, 
VLLLI120211111111 
= TS3,MS7,LB1 


6.3.8 Change/Display DCS Word (ED) 


This directive is used to display and change, or display 
only, the contents of a DCS A or DCS B word. 


The format for the directive is: 


EDdi nnnn 
mmmm Where c = nnnn, 

Cc ‘ 
(c/r) 


Where d is the letter A or B designating DCS A or B, iis the 
DCS address (0-F), mmmm is the contents of the location 
and nnnn is the desired contents. A comma terminator 
causes the display of the next sequential address and its 
contents. A comma terminator to address F effects a return 
to the simulator executive as does the carriage return 
terminator. If no change value is input the contents 
remain the same. 


6.3.9 Begin Simulated Execution (B) 


The begin-simulated-execution simulator directive is used 
to start the simulated execution of the CCS 
microinstructions. 


The format for the begin-simulated-execution directive ts: 
Bmmm 


Where mmm is the control store memory address for the 
Start of the simulated execution. If no CCS address is 
given, then the starting address is the CCS address 
generated as the next CCS address from the last 
microsimulation. However, if the simulator is initialized in 
the meantime, the address will be word zero. 


Examples: 
BO Begin at word O of current page 
B7F 
B Begin from last calculated address 


NOTE: A simulation run can be terminated prior to a 
planned termination by setting SENSE switch 3. The 
simulation run will then terminate upon completion of the 
current micro operation. This feature is useful in terminat- 
ing "run away” simulation runs. 


6.3.10 CCS Address Halt (H) 


The CCS address halt simulator directive is used to set an 
address into the simulator such that whenever that CCS 
address is accessed by the simulator, the simulation 
process will stop. Since control store addresses are between 
O and 1FF (hexadecimal), specifying an address outside 
this range effectively ''turns off" the address halt. Up to 
five halt addresses may be set per page. The default value 
is 200 (CCS word 512). 


The format for the CCS address halt simulator directive is: 


Hann ,nnon.... 
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Where nnn is the (hexadecimal) halt address. 


NOTE: To set multiple halts all addresses must be entered 
under the same H command. 


The halt addresses are set in the page currently selected. 


-"To set halt addresses in another page that page must be 


selected with the '’P’’ command. 


Example: 


H3A9 
H100,10A,IFF,0 


When the halt address is reached, the location and control 
buffer fields are listed on the line printer if the trace 
option is ON. Also, the message '"'CCS HALT”’ is output to 
the TTY and line printer. Then the simulator returns to the 
executive. 


6.3.11 Single Microinstruction Step (S) 


The single microinstruction step simulator directive is used 
to set or reset the single step option in the simulator. When 
the single step option is on, instruction simulation is 
ceased after the execution of each microinstruction. 


The formats for the single microinstruction simulator 
directive are: 


ss Single step ON 
SR Single step OFF 


The first control store word to be executed must be 
specified via the begin (B) directive. To continue with the 
next microword enter the B directive withaqut an address. 


A special form of the SR directive (set single step OFF) can 
be used to set a limit on the number of microinstructions 
to be executed before returning to the simulator executive. 


The format of this directive ts: 
SRnnnn 


Where nnnn is 1-4 hex digits specifying the execution limit. 
When this limit is reached. control] is returned to simulator 
executive. Omission of nnnn results in an unlimited run 
count. 


6.3.12 Trace (T) 


The trace directive controls output to the line printer. The 
trace option is normally ON and pertinent data and 
execution results are listed on the line printer after the 
simulated execution of each control store instruction. 


The format for the directive is: 


TS Set trace ON 

TR Set trace OFF 

TSnnn,mmm Set trace ON from word nnn 
to word mmm 
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If nnn is missing, its value is defaulted to zero. If mmm is 
missing, its value is defaulted to 200 hex (word 512). If TS 
is specified with bounds, the current CCS address is output 
to LO regardiess of whether or not the address is within the 
bounds; however, the remainder of the trace is suppressed. 


The following information is listed on the line printer (LO) 
for each control store word executed: 


1. CCS word address 

2. List of CCS word fields and their values 
NOTE: Fields AA, BB, and FF are dynamically altered 
and need not be equal to the value of the CCS word. 


3. Next CCS word 


4. Current top of stack 

5. Number of items on stack 
6. ALU A input 

7. ALU B input 

8. ALU output 

9. Carry in status (CF) 

10. Carry out status (ALUC) 


11.Contents of the 16 general-purpose registers (RO-RF). 
(4 per line by 4 lines) 


12. Contents of the following registers and flip-flops: 


P Program counter 

sc Shift counter 

OPR Operand register 

KREG Key register processor 

IOKR 1/O key register 

IBR Instruction buffer 

H Instruction register 

STAT Status register 

1OR 1/O data register 

SHFT Sign store of register A bit 15 

QUOS Storage of sign bit (DAL 15) of 
ALU output 


13.Memory Operations Data 
The values listed are the values at the end of the 


memory operations for that CCS word. The memory | 
operations performed are a_ function of conditions/~ 


codes upon entry (values from the last CCS word 

executed). 
When MCCO is less than n and memory wait is required, 
the following memory operations data will appear twice per 
microword trace (n is the memory type specification 3, 4, 
or 5, see section 6.4.2). The first set is an intermediate 
value while the second set represents the values at the 
end of the memory operation. 
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Memory Condition Code 
MCCO = 0 Idle 


MCCO = 1 through (n-1) Active but not done 
MCCO = n Active and done 


where n = memory type specification 3, 4, or 5 (see section 
6.4.2). 


Memory Operation Code 


MOPC = 0 Transfer ALU output to MIL 
and IBR 

MOPC = 1 Read from main memory to 
MIL and IBR 

MOPC = 2 Read from main memory to MIL 

MOPC = 3 Write 16-bit ALU output to 
main memory 

MOPC = 4 Write a byte of ALU output 


to main memory (byte is 
specified by MBYC) 


Main Memory Address Source 


MADS = 0 Address is ALU output 
MADS = 1 Address is program counter 


MADS = 2 Address is memory input 
register (MIR) 
MADS = X Invalid address source 


Byte Designator for Write Operations and 
Field Selection Address 


BYTA = 1 Right byte 
BYTA = 0 Left byte 


NOTE: The byte (of the memory word) not designated is not 
altered. 


Memory Interface Registers 


The contents of registers MIL and IBR are listed. 


Main Memory Address (MMAD) 


The main memory address (as specified by MADS) is listed. 
It is listed for every CCS word executed regardless of the 
actual memory operation as specified by MCCO and 
MOPC. 


Status of test conditions (test inputs). Each status bit 
stored in a separate word of memory and the 16-bit word 
is listed (XXXX). The 16 test conditions are listed on 2 
lines, 8 per line. Each test bit is listed as 0000 = false 
condition; or 0001 = true condition. 


Test Bits 


0 ALU overflow 


1 1/0 sense (continued) 


SSW3 
SSw2 
sswl 
620/f test (for JMP, JMPM, 
XEC groups of instructions) 
6 ALU equals , 
7 ALU sign 
8 ALU carry 
9 ALU zero 
10 Shift flag 
1] MIL 15 (sign bit of memory input register) 
12 Shift count = -]1 
13 A15 - sign of A register for multiply 
operations 
14 DAL 15/DAL 14 (ALU output bits 15 and 14) 
15 QS bit 


mB W fo 


6.3.13 Dump Contents of CCS (D) 


The dump CCS directive is used to list on the line printer 
selected contents of the simulator control CCS and the 
count of the number of times each word was executed. 


The formats for the directive are: 


Dmmm,nnn 
Dmmm 
D,nnn 

D 


Where mmm and nnn are the beginning and ending 
hexadecimal CCS address to dump. If mmm is omitted. 
dump begins at CCS word 0. If nnn is omitted, the 
complete contents of the simulated CCS table is dumped 
starting at mmm. If both m and n are omitted. the 
complete simulated CCS table, starting at location zero is 
dumped. 


The line printer list format is: 


ADDR HEXADECIMAL BINARY 


aaaa hhhhhhhh hhhhhhhh ~~ bbbbbbbbbbbbbbbb bbbbbbbbbbbbbbbb 
bbbbbbbbbbbbbbbb bbbbbbbbbbbbbbbb 
aaaa hhhhhhhh hhhhhhhh ~~ bbbbbbbbbbbbbbbb bbbbbbbbbbbbbbbb 
bbbbbbbbbbbbbbbb bbbbbbbbbbbbbbbb 


Where (aaaa) is the address of the CCS word in hexadeci- 
mal, (hhhhhhhh = hhhhhhhh) is the contents of the CCS 
word in hexadecimal, (bbbbbbbbbbbbbbbb 
bbbbbbbbbbbbbbbb bbbbbbbbbbbbbbbb 
bbbbbbbbbbbbbbbb) is the contents of the CCS word in 
binary and xxxx is the execution count in hexadecimal. 
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The field identifier words and the contents and count of up 
to 14 locations are listed on each page. 


6.3.14 Exit to MOS or VORTEX (R) 


The exit to MOS or VORTEX simulator directive is 


used to effect a transfer of control from the simulator to 
MOS or VORTEX. NOTE: The use of this directive with the 
stand-alone version produces a halt. 


6.4 OPERATING INSTRUCTIONS 


The simulator program operates under either MOS, 
VORTEX, or stand-alone environments. The simulator 
executive communicates with the software environment in 
which it is running by means of the appropriate interface 
program, INTR, provided with the simulator. The user 
communicates to the program via the system Teletype. The 
BLD 1! loader is required when loading of MIDAS object 
programs for execution under the simulator (MOS or 
stand-alone only). 


When operating under VORTEX, the five background global 
control blocks (FCB's) are used when the logical unit is an 
RMD thus permitting the stacking of jobs. The following 
restraints are made on the use of RMD logical units: 

1. SI, Pl, and LO are to be in unblocked format. 

2. Bi must be blocked. 


The simulator data flow 1s shown in figure 6-2. 


OPERATING 
SY STEM 


PI 
DEVICE 


SI 
DEVICE SIMULATOR 
Bl 
DEVICE 
LO sO 
DEVICE DEVICE 
VTU-1809 


Figure 6-2. Microsimulator Data Flow 
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6.4.1 Program Loading 


Under VORTEX, MICSIM can be scheduled from the 
background library at level zero by the /LOAD,MICSIM 
directive. Before scheduling, the number ot WCS pages in 
addition to page zero which will be needed should be 
determined and a /MEM,X directive given. In the /MEM 
directive, X should be the number of additional WCS pages 
(beyond page zero) times 4. 


Under MOS, each time the simulator is to be executed its 
relocatable binary object deck should be positioned on the 
Bi device and the /LOAD directive given. 


In the stand-alone environment, MICSIM is loaded by the 
620 stand-alone FORTRAN IV loader. along with the 
runtime |/O and runtime utility. (Refer to VOM document 
numbr 89A0226, Overview and External Specification for 
information on the 620 stand alone FORTRAN IV 
loader.) The simulator uses logical unit numbers 2, 3, 4, 5, 
and 6 for SI, SO, Pl, LO, and BI. The stand-alone loader 
should be instructed to assign these units to meaningful 
devices. 


Examples: 
Sample Loading Procedures 


1. VORTEX 
/JOB,SIM 
/MEM, x 
/LOAD, MICSIM 


x value = QO, only 1 WCS page; = 4, 2 WCS 
pages; = 8, 3 WCS pages; = 12, 4 WCS pages. 


2. MOS 
/JOB,SIM 
/LOAD 
Test Program (optional) 
Simulator 
EOF (2-7-8-9 multi-punch) 


3. STAND-ALONE 

Load stand-alone loader 

With AID |i, change absolute location 7 ($PED) 
to the desired start load address 

Return to the loader 

Enter the following: 

200300402504602 (c/r) 

(to set S! = TY, SO = TY, PI = PT, LO 
= -77, BI = PT) 

Mount simulator tape in reader 

Enter the following: 


PM 
Load Runtime 1/0 
Load Runtime Utility 


6.4.2 Initial Condition Selection 


After loading, the simulator program is automatically 
entered and outputs the following to SO: 
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PAGE LIMIT ? 


The user then inputs on SI! one of the following: 


0 (for ROM page only) 

1 (for ROM and WCS page 1) 

2 (for ROM and WCS pages 1 and 2) 

3 (for ROM and WCS pages 1, 2, and 3) 


Any other input is an error and the request will be 
repeated. 


MICSIM then outputs to SO: 
MEMORY TYPE 


The user then inputs on SI one of the following: 


3 (for semi-conductor) 
4 (for core) 
5 (for slow core) 


Any other input is an error and the request will be 
repeated. 


Following a correct input, the following is output to SO. 
SI** 


An Si** indicates that the program is in the simulator 
executive awaiting a user command. Control is returned to 
the executive following execution of each command. 


All simulator dialog is entered through the Si device and 
echoed on the SO and LO devices. Dialog may be either 
conversational or batch depending on the S! device 
assignment. All of the simulator directives must be 
terminated with a carriage return; the simulator will output 
a line feed. 


6.4.3 Loading Simulator Central Control Store 
(CCS) and Decoder Control Store (DCS) 


Use the P directive to select the WCS page in which 
simulation is to take place. 


Use the L directive to load the micro assembler output into 
the specified simulator control store (central or decoder). 


Use the M directive to select the input device; either SI or 
PI. 


Use | directive to initialize to zero all the simulator 
registers, test conditions, control store buffer, status 
registers and execution count table. 


Use the A directive to initialize the program counter, file 
registers, and instruction register as required. 


Position the 620/70 sense switches as required. The 
simulator program monitors the 620/70 sense switches 
similar to the computer sensing of its control-panel 
sense switches. 


6.4.4 Other Control (As Required) 


Use the E directives to make any patch corrections to the 
CCS or DCS. 


Use H directives to set simulation halts when the specified 
control store address is reached. The initialized address is 
200 hex. and will remain such until specified otherwise. 


Use S directives to specify single step operation as 
required. The initialized condition is run (not step). 


Use T directives to specify operation with or without trace 
listing as required. The initialized condition is with trace. 


6.5 PROGRAM EXECUTION 
After. all initiatization and start-up conditions are specified, 


use the B_ directive to begin execution at the specified 
control store address. 


6.6 AFTER SIMULATION 


6.6.1 Control Store Dump 


Use the D directive to dump the control store words and 
the execution counts for each control store. 


6.6.2 Initialization 


Use | directive to initialize registers, tables, etc. prior to 
making another run. 


6.6.3 Return to MOS, VORTEX 
Use the R directive to return to MOS or VORTEX as 


required. (NOTE: In the stand-alone version this command 
effects a halt). 


6.7 620 EMULATION 


To run programs using the 620/f emulation ROM, the 
following sequence of events must be done: 


Note that CCS page 0 and DSC initially contain 620 
emulation values. 


1. Set CCS halt to 080 (hex) via H command. 
2. Set R5 to FFFF (— 1) via AR5 command. 
3. Set other registers and sense switches as needed. 


4. Set pseudo P register to location (hex) of first macro to 
be executed via AP command. 


5. Set trace and step/run mode as needed. 


6. Begin at 13E via B command. 
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The sequence of events 1 through 5 may be in any order 
but must be done before event 6. Event 6 begins 
simulation at standard state 1. 


6.8 MAIN MEMORY SIMULATION 


Simulation of main memory operations is restricted so that 
a simulation run does not destroy the simulator or related 
programs. This is accomplished by not simulating writes to 
memory addresses outside defined main memory. Any 
attempt to do this will be flagged as an error and the write 
will not be performed; simulation will continue however. A 
read may be made anywhere in available memory. Memory 
addressing above 32K will effect wraparound if available on 
the computer. 


Loading Main Memory 


A 200 (octal) word block of memory has been created at 
the beginning of the simulator. The name MMEM points to 
the start of that block and the name EMEM points to the 
end of the block. A DASMR program with an ORG within 
this block can be loaded by MICSIM from the BI device 
using the LM directive. The object program to be loaded 
must not contain any of the following: 

a. Literals 

b. Indirects 

c. Entrynames 

d. Externals 


lf any of these are encountered, the load is aborted and a 
MS11 diagnostic results. 


The location of MMEM can be found in the load map. (It is 
always the first loaded location of MICSIM). 

6.9 SIMULATOR ERROR MESSAGES 

MESSAGE REASON 


General 


MSOl Input could not be interpreted as a valid 
command. 


MSO02- A non-hex character was encountered when 
hex expected. 


initialization 


MS03 Insufficient common area to contain specified 
number of pages. 


MS04__—s The selected page number was not valid. 
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CS Addressing 


MSO5 An attempt was made to jump to an 
unavailable WCS page. 


MSO6 A BCS instruction was encountered when 
WCS page 1 is unavailable. 


CS Loading 


MSO7_ ‘Read error on BI device. 
MSO8 EOF encountered before load complete. 
MS09 EOD/BEOD encountered before load complete. 


MS10 Sequence error on BI. 
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MS11 


MS12 


Memory 
MS13 


MS14 


MS15 


Invalid loader code. 


Checksum error. 


Undefined macro opcode. 


Attempted to write to memory outside defined 
main memory. 


Attempted to load outside defined main 
memory. 


Field Selection 


MS16 


MS17 


Invalid field name. 


Invalid field value. 
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6.10 EXAMPLE OF SIMULATOR OUTPUT 


Figure 6-3 shows the simulation listing of the LDA example 


developed in section 2. 


PAGE 


VARTEX MYCSIM 


VARTAN 735 MICRO STMULATOR 


PAGE LIMIT? 


0 


“FROQY TYPE? 


4 
MSaw 
Ft) 
“S* 
CPO 
ANAAD 
{OF9 
MSank 
CFO 
N36 


“Sax 
4P 
onnn 
2an 
Saxe 
§R7 
Sux 
RYE 


SELFCT PAGE ZERO 
PIT AN TLOA INST IN MEMORY FOR SIMULATION 
LOA FRNM MEMNRY LOC tegt 


CHEEK VHATS TO BE LOANEN 
SET PRIIGRAM EPUNTER TON THE tL Dal 


SET FXFCUTION LIMIT TO SFVE® MICRONS 


REGIN FXECUTTON AT STANDARD STATE ONE, SS1IM 


Figure 6-3. Simulator Output Format 


611 
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PAGE 
ccs 


TS 
00 


RF 
00 


NEXT 


nnn! 
ac 


AF 
09 


PF 
00 


01 


MS 
02 


MF 
On 


SE 


MT 
no 


CF 
an 


CCS ANNRESS 


PaGE 


FS 
00 


WR 
00 


N092 


CURRENT TMP OF STACK 
NUMBER OF ITEMS ON STACK 


ALU 
ALU 


6-12 


QO eo &* ve 


INPUT A 0000 
INPUT B GO00O0 
NUTPUT 0000 

0 

tT 0 
N0nN0 RI o000 
C1}O00 RS FFFF 
On00 RG NON 
0000 RD 0000 
Sc OPR KREG 
n000 000 000 
n000 
0000 
0200 10F9 

TES 
SENS SSw3 SS8w2 
0900 9000 0000 
ALUZ2 SHFT MIRS 
0000 0000 0000 


VORTEX 
0 
TF SF GF MR AB 
00 O1 00 090 00 
SC VF wr xXF Sh 
00 00 06 90 40 
PAGE 9 
0000 
0 
R2 0000 RS ANDO 
R6 OnN00 RF 0006 
RA 0000 RB 0000 
RE 000060 RF 9Q009 
TOKR JAR I 
0000 oannn anan 


Y CONOITION STATES 


SSwi EMUL 
0000 0000 
SFTC ROAD 
0000 .0000 


aALud 
00006 


NORM 
6000 


MICSIM 


I™ 
08 


BB 
00 


STAT 
000 


ALUS 
0000 


auoSs 
6000 


Figure 6-3. Simulator Output Format (continued) 


L6 
00 


AA 
00 


LA 
00 


TOR 
0000 


SHFT 
0000 


QUNS 
0000 


PAGE 0002 
CCS LAC 0092 


TS AF MS MT 
00 02 On 0 


RF FF mF CF 
04 09 90 06 


NEXT CCS ADNRESS 


CURRENT TOP OF § 
NUMBER OF ITEMS 


ALU INPUT A OO 


ALY YNPUT 8 AN 
ALU NUTPUT an 
CIN 9a 
Cnutr o 


RO On00 RY 
R4 Q000 RB 
R&8 Oonod RY 
RC 6000) ROA 


Pp sc MPR 
0201 000 anne 
MCCN 4 

MOPC 1 

MADS 1 

MBYC 0 

MIR onan 

IBR 0000 


MMA 0200 10F9 


VORTEX 


PAGE 0 


FS TF SF GF .MR AB 
00 060 Of Of Of OO 


WR SC VF wF xXF SH 
a0 00 00 On on 0a 


n02n PAGE 4 


Tack 0000 
ON STACK 0 


00 
no 


an 


0000 R22 90060 RS On00 
FFFF RE& O0OO RIF 00ND 
0000 RA 0000 RB 9000 
O0N00 RE 0000 RF nnn 


KREG YOKR YBR J 
onon0 900% on00 ANNO 


Figure 6-3. Simulator Output Format (continued) 
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LA 
00 


INR 


MICSIM 
Im’ LB 
08 00 
BB OAA 
00 00 
STAT 

Anan 


0000 


SHFT 
0000 


ALINS 
9000 
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PAGE 


mec) 
MOPC 
MANS 
KAYE 
MIR 
TAR 
MM At) 


(VEL 
enna 


ALLIC 
N004 


ANOS 


{OF9 
{Ora 
0201 


SES 
Hane 


ALu2 
Non 


anno 


TEST 
$8w3 
9006 


Sr T 
ognn 


VORTEX 


CONDITION STATES 
SS¥2 SSw{ EMU. 
ON09 O000 antn 


MTRS SFTC ROAN 
jsneo anan anann 


ALO 
00a 


NORM 
nang 


Figure 6-3. Simulator Output Format (continued) 


MTCSIM™ 


AL US 
Anon 


AuUNS 
AnNN 


PAGE O00N4 


n020 PAGE 0 


MT 
N0 


mS 
06 


FS 
ole 


TF 
00 


MEF 
00 


wR 
ele 


CF 
00 


§¢ 
00 
ONRESS 0182 
P NF STACK 
TTEMS OW STACK 
T aA OOOO 

Y RB ONCN 


“Uy GNA 


9NON 
FREE 
00090 
‘ollezena) 


PR 
O009 


KREG 
Annan 


0000 


ccs Loc 
Ts AF 
Oo—& on 
RF FF 
on 00 
NEXT CCS A 
CURRENT TU 
NUMBER OF 
ALL INPL 
Al. TNPIY 
ALU NuUTeP 
CI 0 
COUT Oo 
RO anon 
R4 Oonnn 
R8® “Anno 
RC O00 
P §¢ 
0201 aAanot 
mCCO 2 
MOPC 1 
MAODS 1 
MBYC 0 
MIR 1OFQ 
IBR 1OF9 
MMAD 02014 
OVFL SENS 
0000 000 
ALUC aALUZ 
0000 0000 


0009 


TEST 
SSw3 
aCc00 


SHET 
oo0n 


SF 


00 


VF 
nn 


PAGE 


0 


9N00 
0000 
o000 
0000 


TNKR 
9000 


VORTEX 


GF 
05 


WF 
on 


0 


TRR 
iQF9 


CONDITION STATES 


SSw2 
9000 


MIRS 
0000 


SSwi 
0000 


SFTC 
0000 


EMUL 
0000 


ROAD 
0000 


MR 


on 


XF 
0” 


SH 


ALUO 
0900 


NORM 
0000 
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MICSIM 


L8 
00 


LA 
oc) 


AA 
00 


SHFT 
g000 


NUNS 
Anan 


STAT 
gang 


TOR 
0000 


ALUS 
0000 


QU08 
9000 


Figure 6-3. Simulator Output Format (continued) 


MICROPROGRAM SIMULATOR, MICSIM 


PAGE 
CCS t 


TS 
on 


RF 
03 


NEXT 


00% 


O¢ 


AF 
12 


FF 
CA 


O41 


«S 
OF 


MF 
oF 


82 


MT 
n0 


CF 
A3 


CCS ANDRESS 


PAGE 


FS 


on 


wh 
01 


OV oF 


CURRENT TOP JF STACK 


NUMBER OF LTEMS MN 


ALU 
Alt! 


Ala 


CIN 
omely) 


RA 
na 
RB 
RC 


616 


STA 


INPUT A ACOO 


TNPH 

NTP 
re) 
TO 


AAGO 
NoAan 
O06 
000 


$c 
nnnn 


Gwe ee 


LOF9 
10F9 
0201 


T 


Wt 


« OG 


Fg 


COF 9 


R 1 
RS 
R9 
RD 


JPR 
Q0F9 


0000 


OnNN 
FREE 
Anan 
Oogoa 


KREG 
CO00 


0 
TF SF 
00 at 
sc VF 
01 00 
PAGE 
nano 
ck 0 
R2 0000 
R6 0000 
RA 0006 
RE 0000 
1OKR 
0000 


GF 
00 


uF 
on 


0 


IA 


VARTEX 


Q3 
R7 
RA 
RF 


R 


10F9 


MR 
nn 


XF 
an 


nann 
0000 
A000 
0000 


- 


LOF9 


MICS 


IM 
n5 


Be 
00 


STAT 
qanon 


Figure 6-3. Simulator Output Format (continued) 


I™ 


LA 
92 


AA 
00 


LA 
AY 


IAR 
NdQgn 


SHFT 
0000 


Quoas 
A000 


PAGE 


MCCO 
MOPC 
MADS 
MBYC 
MIR 
IBR 


MMAD. 


NVEL 
000 


ALUC 
0000 


0006 


oOoONR = 


0000 
0000 
OOFS 


SENS 
0000 


ALUZ 
0004 
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VORTEX 


TEST CONDITION STATES 


00356 

SSW3 SSw2 
0900 00060 
SHFY MIRS 
2000 0000 


8Swi 
0000 


SFTC 
0000 


EMUL 
0000 


ROAf) 
0000 


ALUO 
0000 


NORM 
0000 


Figure 6-3. Simulator Output Format (continued) 


MICSIM 


ALUS 
0000 


Qu08s 
0000 
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PAGE 0007 

ccS Loc) 3=— «oF 
78 AF MS MT 
00 1£ oc oO! 
RF FF MF CF 
00 00 00 90 


NEXT CCS ADDRESS 


CURRENT TOP OF STACK 


NUMBER OF ITEMS ON STACK Q 


ALU INPUT A 0000 
Alt TNPUT & 0000 


ALo! OUTPUT cann 
CIe oO 
cout oO 
R‘ QH00N RY nt 
R4 ANNH RS FF 
RA anae RY At 
RC acco RN OA 
-) §C NPR 
N20} nacn AYFY 
MCCN 2 
MOPC 2 
MANS O 
MBYC 0 
MIR C000 
TBR 0000 
MMAD QOF9O 0036 
TEST 
OVFL SENS §SW3 
AN00 oOon0o n00C 
ALUC ALUZ SHFT 
9000 0000 1000 
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VARTEX 

AGE 0 
FS TF SF GF MR AB 
OF OO 006 00 AN QO 
wR SC VF wF XF SH 
00 00 00 00 an a0 
O1E0 PAGE 90 

0000 
NO R2 N000 PSX NOAA 
FF R6 000 RZ ONnNnN 
10 RA 0000 96 nn0ne 
O00 RE 9000 RF O000 
KREG JOKR JAR if 
COOO6 O00 Onn 10F9 
CONNITION STATES 


SSw2 S$Sat EMUL 
0000 0000 0090 
MIRS SFTC ROAD 
ONN0 O0f00 0000 


ALO 
0000 


NORM 


0000 


MICSIM 


IM 
10 


RB 
n0 


STAT 
900A 


AL US 
0090 


QU0S 
A000 


Figure 6-3. Simulator Output Format (continued) 


LB 
00 


AA 
00 


LA 
00 


INR 
Qgad 


SHFT 
ANON 


QAUNS 
oany 


PAGE 008 


ces Loc 
TS AF 
10 OR 
RF FF 
04 00 


01&0 


MS 
05 


MF 
00 


MT 
00 


CF 
00 


NEXT CCS aNCRESS 


PAGE 


FS 
00 


wR 
an 


NOB5 


CURRENT TOR OF STACK 
NUMBER AF TTEMS ON STACK 


ALI) INPUT & 9000. 
INPUT BR O00 


ALU 
ALU: OUTPUT 
CIN 0 
COUT oO 
RO Onno 
R4 AN0O 
RB 000 
RC 0000 
P s¢ 
0202 000 
MCCO 4 
MOPC 2 
MADS 0 
MBYC 0 
MIR 0000 
IBR 0000 
AMAD OQOFQ 


R4 
RS 
RO 
RD 


0 


OPR 
OOFS 


0056 


Oe 


0000 
FFFF 
0000 
0000 


KREG 
000 


0 
TF SF 
00 Of 
SC VF 
nO 00 
PAGE 
o00n 
0 
R2 0000 
R6 oOnae 
RA QAgdN 
RE 00600 
TOKR 
0000 


VORTEX 


_ MR 


00° 


wk 


TA 


R 


onon 


00 


KF 
00 


AB 
on 


SH 
00 
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MICSIM 
m™ 18 
08 00 
BB OAA 
00 00 
STAT 

qann 


Figure 6-3. Simulator Output Format (continued) 


LA 

00 
TOR SHFYT QUNS 
0000 0000 9000 
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6 20 


PAGE 


MOCO 
MOPEC 
MADS 
MBYC. 
MIR 

TBR 

MMAD 


VEL 
0000 


ALUC 
0000 


NADY 


Ss = oo we 


nA36 
annn 
N202 


SENS 
anno 


ALUZ 
nnnn 


no0gn 


TEST 
$S43 
nnan 


SHFT 
naan 


Figure 6-3. Simulator Output Format (continued) 


VORTEX 


COMNNMITION STATES 


SSw? 
vHo00 


MIRS 
OnAO 


SSwi 
0000 


sere 


nodaa 


EMUL 
0000 


ROAO 
onan 


ALLO 
9000 


NORM 
naan 


MICSIM 


AL.US 
0000 


QUNS 
nann 


PAGE 010 VORTEX 
ccs Loc 0085S PAGE 0 
TS AF mS mT FS TF SF GF wR AB 
OF 0D 06 00 0060 00 00 O08 00 00 
RF FF mF CF wR SC VF wE YF 8H 
00 OA Of 00 O1 00 00 0060 0 00 
NEXT CCS ANDRESS 0080 PaGE 0 
CURRENT TOP HF STACK 0000 
NUMBER OF ITEMS ON STACK 0 
ALU INPUT A 0000 
ALU) JNPUT B O36 
ALU MUTPUT 9036 
CIN 0 
court a 
RO 036 RI AH0H RB 0000 R3 0000 
R4 1000 R5 FFFF R6 Of00 RZ 0000 
RB O00 RO N00 RA 0000 RB 0000 
RC 0000 RAM Of00 RE 000 RF 0000 
Pp ie OPR KREG INKR IBR 1 
0en2 no00 ONnFYQ Nn000 0090 0000 0000 
MCCO 2 
MOPC | 
MANS | 
MAYm 0 
MIR O036 
IRR 0000 
MMAD 9202 0000 
TEST CONDITION STATES 
OVFL SENS SSW3 SSW2 SSwi EMUL aLuo 
6100 A00H 0900 4000 0000 0n00 0000 
ALUC ALUZ SHFT MIRS SFTC ROAQ NORM 
0000 0000 0000 0000 0000 6000 0000 


EXECUTION LIMIT SATISFIED 
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MICS 


IM 
06 


8B 
01 


STAT 
0000 


ALUS 
0000 


QUOs 
0000 


Figure 6-3. Simulator Output Format (continued) 


IM 


LB 
O1 


AA 
00 


LA 

00 
TOR SHFT Alns 
0000 0000 0000 
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SECTION 7 


MICROPROGRAM UTILITY PROGRAM, - 


MIUTIL 


The microprogram utility (MIUTIL) loads information into 
WCS and provides an interface with hardware features of 
the WCS. 


Two sets of directives are provided. The basic set will allow 
the user to load the WCS with microassembler output, 
examine single WCS words and list WCS contents. The 
second group of directives gives the user access to the 
debugging features of the contro! store. With these 
directives single microstep execution can be done. 


The utility operates in three environments, under the 
VORTEX operating system, MOS operating system and as a 
Stand-alone program. A standard interface program pro- 
vides compatibility. 


7.1 BASIC ELEMENTS 


The microprogram utility accepts directives as similar as 
possible to those of the microprogram simulator. 


7.2 GENERAL FORM OF DIRECTIVE 

In general a utility directives consists of a unique first 
character, followed by a string of parameters, terminated 
by a carriage return. The following sections describe the 
meaning of each of these first characters and permissible 
parameters. Table 7-1 summarizes the utility directives. 


The following are the utility directives available to the user: 


Table 7-1. Summary of Utility Directives 


A. Basic Command Set 


Pn - Page select 

LC Load central control store (CCS) 

LDA Load decoder control store (DCS) A 

LDB Load decoder control store (DCS) B 

MS Media set, selects Pl for input 

MR Media reset, selects S! for input 

Exm Examine/change control store x word m 
Dxm,n Dump control store x word m through n 

R Return the operating system or exit from 


utility in stand-alone environment 


B. Debugging Directives 


Nx Enables control store x 

TS Trace set 

TR Trace reset 

Gn Set microprogram execution address to 
CCS word n 


(continued) 


Xn Execute n microinstructions 
| Initialize WCS 

Bn Branch to CCS word n 

Hn Halt execution at word n 


7.3 DIRECTIVE DEFINITIONS 


In the following discussion of utility directives, the 
characters the user inputs are in bold-face type and 
explanation of the action in regular type. 


All numeric values are hexadecimal. 


7.3.1 Select Page (P) 


This directive selects a particular WCS page for the 
commands which follow. The directives for loading, and 
dumping do not accept a page number and thus rely on the 
previous P command for page selection. 


Before the first P command is given by the user, a default 
page value of 1 is assumed. 


The letter P is followed by a hexadecimal digit for the page 
number. For example P3 would select page 3. 


7.3.2 Load Control Store (L) 


This directive loads microassembler output into the 
writable control store. The user specifies which page is to 
be loaded by the prior P command. The user specifies 
which control store should be loaded by the one parameter 
following the letter L. C indicates central control store, DA 
or DB for decode contro! store A or B, and | for |/O control 
Store. 


For example, after P2 a directive LC would load page two of 
the central writable control store. 


7.3.3 Examine/Change Control Store (E) 


Through this directive a single word of WCS may be either 
examined or changed. The user specifies which control 
store and the word number. The page is obtained through 
the previous P directive. 


The form of the E directive is Exmmm where x is either 
C, DA, DB or | for central, decoder, and |/O control stores 
respectively, and mmm is the address of the control store 
word in hexadecimal notation. 


7-1 


MICROPROGRAM UTILITY PROGRAM, MIUTIL 


The utility will type out the contents of the location 
followed by a carriage return. The change value format is 
the same as the microsimulator format. Refer to section 
6.3.7 for details. 


For example 
Action Caused 
MU** 
Pl Selects page 1 
MU** 
E129 Examine !/0 control store location 29 
12A3 Computer types contents 
QO, User changes contents to zero 
002A 
1233 Computer types location 2A 
0 User changes its contents to zero 
MU** 
ECF Utility accepts another directive 


7.3.4 Dump Control Store (D) 


The dump directive provides a listing of the control store 
contents. The page is determined by the prior P directive. 
The user specifies the locations and control store type in 
the parameters. 


The general format for the dump directive is: 
Dxmmm,nnn 


where x is C, DA, DB or | for the specific control store (as 
above), mmm is the hexadecimal! location where the dump 
is to start, and nnn is last location to be dumped. If the 
final location is missing, the last location of the page is 
assumed. If the first address is omitted, it is assumed to be 
zero. 


Dump directive example: 


MU** 

P2 

MU** 

DC Provides listing of central control 
store page 2 

MU** 


DI30,5A Provides listing of the 1/0 control 
store, locations 30 through 5A 

MU** 

DI,5A List from location zero through 5A 

MU ** 


Section 7.8 shows a sample printout ot the microprogram 
utility directive D. 
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7.3.5 Return to Operating System (R) 


This directive causes exit from the utility. If running under 
MOS or VORTEX, control is returned to the operating 
system. If the utility is running in a stand-alone environ- 
ment, the R directive causes a halt. There are no 
parameters, merely the letter R. Under VORTEX, any WCS 
changes via LC or EX commands are copied to WCS and 
the disc image file WCSIMG. 


7.3.6 Media Set and Reset (M) 


This directive allows the selection of an alternate device for 
input of utility directives. 'MS' selects the ‘Pl’ unit for 
input. 'MR' returns the utility to the S! unit for input. 


Note that receiving an illegal command will cause the 
media to be automatically reset to S!. 


The following directives are designed to operate in the 
special hardware configuration described in section 7.5. 


7.3.7 Enable Control Store (N) 


This directive allows the user to enable the specified control 
stores. The page number used in the one specified by the 
last P directive. 


The general form of the N directive is: 
Nx 


where x is D or J, which specifies enabling of the decoder or 
1/O control store, respectively. 


For example: 


MU ** 

Pl 

MU*? 

ND Enables decoder control store, WCS page | 
MU** 


7.3.8 Trace Execution (T) 


The purpose of this directive is to provide the user with a 
means of following micro execution while it is in progress. 
To accomplish this, the address of each microinstruction is 
typed before it is executed. 


The genera! form of the T directive is: 
Ta 


where a is one of the following: S for setting or enabling 
trace mode, or R for resetting or disabling trace mode. 


Before the first T directive is given, the trace mode is reset, 
i.e., turned off. 


The general form of the trace output is: 

p-nnn 

where p is the page number and nnn is the word number of 
the next instruction to be executed. 

7.3.9 Set Micro Execution Address (G) 


This directive allows the user to choose a location for 
starting microprogram execution. 


This routine will do the following: 


1. Step the WCS to stop any execution that might be in | 


progress. 


2. Load the micro address register with the specified 
address. 


3. Step the WCS to load the first microword into the 
control buffer. 


4. If trace mode, the next contro! store address to be 
executed will be read from the WCS and output to the 
user. 


This directive does not begin execution. It serves only as 
the setup for an X directive. 


The format of the G directive is as follows: 
Gn 


where n is from one to three hex digits specifying a word 
number in central control store. 


The page is obtained from the last P directive. 


7.3.10 Execute Microinstruction (X) 


This directive is used after the G directive to begin actual 
micro execution. It can be used to specify free-running 
execution or execution of a fixed number of micro’s 
followed by a halt. By requesting execution of a single 
micro, followed by a halt, it can be used to stop free- 
running execution. 


If free-running execution without trace is requested, the 
fine clock will simply be enabled to run free. There are two 
ways of interrupting this. An X directive specifying 
execution of one microinstruction will step the WCS. It can 
then be restarted by another X directive. The G directive 
will also “stop free-running execution. It sets a starting 
address, however, and thus it should not be used if the 
interrupted execution is to be restarted where it left off. 
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If free-running execution is requested in trace mode, then 
the WCS is simply single stepped an indefinite number of 
times. This allows reading of the WCS address before each 
single step. 


If execution of a fixed number of microinstructions is 
requested, the WCS will simply be stepped the appropriate 
number of times. If trace mode, then the address will be 
accessed from the WCS and returned to the user before 
each micro is executed. 


The following is the format of the X directive: 


Xn 


Where n is zero for free-running execution or non-zero to 
request execution of n microinstructions. 


The default value for n is 1. 


For example: 


X7 Execute seven microinstructions 
x0 Enable free-running execution 


x Execute one microinstruction (note: this 
would halt the previous free run) 
MU** 


7.3.11 Initialize WCS (1) 


The purpose of this directive is to execute an EXC 07X 
command. This will deselect all WCS control stores, 
terminate any DMA operations in progress and enable free 
run of the fine clock. The result is that control will return to 
the ROM with all WCS activity suspended. 


This command should only be used when a meaningful 
ROM location will receive control. Thus, it should not be 
used for such things as halting a_ free-running 
microprogram. 


7.3.12 Branch to CCS (B) 


This directive simply executes an I/O branch to the 
specified address in central contro! store. Such a branch 
causes free run execution to begin at that location. The B 
command thus produces a similar effect to a Gn, X0 
directive sequence. The B directive never steps the WCS 
though, and thus cannot respond to the trace flag. 


The general form of the B directive is: 
Bn 


Where n is from one to three hex digits specifying a word 
number in central control store. 


The page number is obtained from the last P directive. 


7-3 


MICROPROGRAM UTILITY PROGRAM, MIUTIL 


7.3.13 Set Halt Address (H) 


This directive may be used with the X directive to single- 
step microprogram execution to a certain address in WCS. 


The format of the H directive is: 
Hn 


where n is from one to three hexadecimal digits specifying 
a word in control store. The page number is specified in the 
last P directive. 


Single stepping as a result of an X directive will be 
terminated when the specified location is the next one to 
be executed. A message in the trace format will be output 
to signal this. 


The halt can be removed by entering HO. Only one halt 
address may be set at a time. 


7.4 OPERATING INSTRUCTIONS 


7.4.1 Program Loading 


Under VORTEX, load VORTEX as described in the VOR- 
TEX Reference Manual. The utility should be in the 
foreground library. It can be put there at system genera- 
tion time or added later using the load module generator. 


To load the utility and begin execution, an OPCOM 
schedule directive is necessary. For example: 


;SCHED,MIUTIL,3,FL,F 
schedules the utility at priority three. 


Under MOS, load MOS as described in the MOS Reference 
Manual, 98 A 9952 09x. Then, the MOS loader may be used 
to load the utility program. Execution will begin on 
successful completion of the load. 


For example: 


/JOB, UTIL 

/LOAD 

Utility program binary object 
EOF (2-7-8-9 multi-punch) 


In a stand-alone environment, load the 620 stand-alone 
FORTRAN IV system loader. Instruct the loader to 
change its logical unit numbers by entering appropriate 
values. Next, load the utility binary object, followed by 
the FORTRAN IV stand-alone system runtime I/O tape, 
followed by the runtime utility tape. On completion of 
loading, the machine will go into step. Press RUN to start 
execution. 


7.4.2 Program Execution 


After successful loading, the utility program is entered 
automatically. The program will first type MICRO 
UTILITY to identify itself. Next, the configuration will be 
determined by the following request: 


DEBUG CONFIG? (Y or N) 


The user should then type Y followed by a carriage return, 
if his system is in the special two-processor debugging 
configuration described in section 7.5. Otherwise, if his 
system is simply the standard configuration, the user 
should type N, followed by a carriage return. 


Under the stand-alone and MOS environments, the micro 
utility will then type 


EVEN WCS DEV ADDR ? 


The user should then type either 70, 72, or 74, depending 

on the hardware configuration, followed by a carriage 
return. This request is not made under VORTEX because 
the device address is specified at SYSGEN time. 


The utility will then type: 


MU ** 


to indicate that it is ready to accept a directive. Whenever 
an illegal directive is given, an error message is typed. 
Description of the various messages can be found in 
section 7.7. Note that a directive may be in error either due 
to bad syntax or due to context. An example of the fatter 
case is giving a debugging directive in a non-debugging 
configuration. 


During execution of the D and X directives, SENSE switch 3 
may be set to terminate their execution prematurely. 


SENSE switch 1 may be set during tracing to suppress 
listing of page zero addresses. 


7.5 DEBUGGING CONFIGURATION 


The additional debugging directives of the utility -annot 
operate on the WCS of the processor on which the utility 
itself is running. For this reason, a special hardware 
configuration is needed to use these directives. 


The special configuration must have two computer systems: 
one with a WCS and the other actually operating the utility. 


The system which runs the utility program must have the 
hardware appropriate for the type of operating system or 
for stand-alone operations. The processor need not have 
any WCS and the processor itself can be either a 70-series, 
620/f, or 620/L. Operating system requirements prevail, 
since VORTEX does not run on a 620/L. 


The Writable Control Store Reference Manuals describe 
the physical properties of this two processor system for 
debugging. 


7.6 UTILITY ERROR MESSAGES 


Message 


General 


MUO] 


MU02 


MU03 


MU04 


MU05 


MU06 


~ Reason 


Input could not be interpreted as a_ valid 
command. 


A non-hex character was encountered when hex 
expected. 


EOF detected on Si. Return mode to operating 
system. 


The selected page number was not valid. 
WCS Access 
Unable to access WCS: WCS is busy. 


Unable to access WCS: BIC load in progress. 


Message 
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Reason 


CS Loading 


MU07 


MU08 


MUO09 


MU10 


MU11 


MU12 


Read error on BI device. 

EOF encountered before load complete. 
EOD/BOD encountered before load complete. 
Sequence error on BI. 

Invalid loader code. 


Checksum error. 


Field Selection 


MU16 


MU17 


invalid field name. 


Invalid field value. 
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7.7 EXAMPLES 


The following is a sample of microutility output: 


PAGE 0000 09/07/78 
VARIAN 73 MICRO UTILITY 


VEBUG CONFIG ? (Y OR N) 
N 


Mee 
tC25 

00009000000000000 

¢ 

v026 

0000000000000000 

, 

0027 

000909090000000000 

BA, 

0028 

0000900000000000 

Mijwe 

U0a8,8 

PAGE 0O0Q1 09/07/73 
UCS aA , PAGE OQ} 

0008 0009 =+.O00 0000 
Allan 

LOB 

PAGE 0002 09/07/73 
VCS 8 , PAGE QI 

0000 0000 9900 =Q000 
0008 0000 0000 9000 
MUwe 

vC5,7 
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0000 


0000 
9000 


VORTEX 


VORTEX 


VORTEX 


0000 
0000 


0000 
0000 


MIUTIL 


MIUTTIL 


MIUTIL 


0000 
0000 


9000 
0000 


PAGE 0003 09/07/73 


0005 

MS MT 
00 00 
ME OCF 
00 00 
0006 

MS MT 
00 00 
MF OCF 
00 00 
v007 

MS MT 
00 00 
MF OCF 
00 00 


CCS Enc 
TS AF 
00 Qo 
RF FF 
060 90 

CCS 4, 0c 
TS AF 
0©O 00 
RF FF 
oo 86900 

Ccs Luc 
TS AF 
00 00 
RF FF 
oo 8600 

MUee 

LC 

LOAD COMPLETE 

MUne 

Lt 


LQOad COMPLETE 


Mune 


PaGE Oj 
FS TF 
oo Q0 
wR §C 
00 oOo 

-PAGE QO} 
PS TF 
00 6000 
wR $C 
00 00 

PaGE O1 
FS TF 
00 «Of 
wR $C 
00 00 


SF 
00 


VF 
00 


SF 
00 


VF 
00 


SF 
00 


VF 
00 


GF 
00 


WF 
00 


GF 
00 


we 
00 


GF 
09 


id 
00 


VORTEX 

MR AB 
00 00 
XF SH 
00 00 
MR AB 
00 00 
XF SH 
00 00 
MR AB 
00 00 
XF SH 
00 00 


MIUTIL 
IM L868 
00 600 
BB AA 
00 900 
IM LB 
00 00 
BB AA 
oo 00 
Ix LB 
00 00 
@B AA 
00 00 


LA 
00 


LA 
00 


La 


00 
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SECTION 8 


DECODER CONTROL STORE, 1/0 
CONTROL AND ADDITIONAL TOPICS 


These topics are not of interest to all microprogrammers. 
Both decoder and 1{/O control stores are options and also 
less trivial to program. Not all applications require an 
understanding of the item treated as additional topic 
which is multiple environment applications. 


8.1 DECODER CONTROL STORE 


Preliminary decoding of instructions in the instruction 
buffer can be performed by the instruction decoder 
control store and the instruction decoding logic. These 
elements translate the 16-bit instruction into a 9-bit 
control-store address according to the contents of the 
instruction decoder control store. 


Decoder addressing is used to perform a preliminary 
instruction decoding function. It permits instruction classes 
to be discriminated with the detailed decoding performed 
later by field-selection addressing after the instruction 
buffer is transferred to the instruction register. 


The instruction decoder contro! store consists of two 16- 
word by 16-bit memory arrays. The processor implements 
this with programmable read-only memory (PROMS). An 
option of the WCS permits selection of read/write arrays to 
permit alternate decoding strategies. 


The decoders are identified as A and B. Bits within them 
numbered right to left starting with zero, so that bit 10 of 
decoder B is identifed as B10. A and B designations are 
accepted by microprogram simulator and utility programs. 


The formats for these two control store arrays are shown 
in figure 8.1. 


A specific Decoder B contro! store word is accessed by 
using instruction buffer bits 12-15 as an address. Access 
to Decoder A words is via bits 8-11 of the instruction 
buffer. The selected A and B words are used to generate a 
9-bit WCS address as shown in table 8.2. 


The decoder address is enabled by the TF and SF fields 
both equal to 00 and the GF field equal to X1XX. If an 
interrupt is present, decoding is inhibited and interrupt 
addressing is used. 


Decoder addressing will be inhibited if the IM field equals 
11X0. If decoder addressing is so inhibited and no 
interrupts are present, field-selection addressing is used. 


The possible components of a decoded address are shown 
in figure 8-1 and 8-2. The nine low-order bits obtained from 
the decoder B are always used in decoder addressing. 


The five most significant bits (4-8) in decoder A are 
included in the contro! store address bits 4 through 8 by an 
inclusive OR, if either of the following bit combinations 
exist in the first decoder output: 


B12 equals zero 
or 
B15 equals zero 
The four least significant bits of decoder A are included in 
the contro! store address bits 0 through 3 by an inclusive 


OR if either of the following bit combinations exist in the 
first decoder output. 


B12 equals zero and B10 equals one 
or 
B15 equals zero and B10 equals one 


The contents of instruction buffer bits 04 through 07 are 


_included in the control store address bits 0 through 3 by 


an inclusive OR, if either of the following bit combinations 
exist: 
B14 equals zero 


or 
B15 equals zero and Al3 equals one 


The contents of instruction buffer bits 00 through O3 are 
included in the contro! store address bits 0 through 3 by 
an inclusive OR, if either of the following bit combinations 
exist: 


B13 equals zero 
or 
B15 equals zero and A13 equals one 


One exception to this is the contribution of instruction 
buffer bits 04 through 07. The contribution to control store 
addres; bit 2 will be the contents of instruction buffer bit 
03 instead of bit 06, if the decoder B bit 00 equals one 
and the decoder A9 equals one. 


The meaning of other bits in the two decoder control store 
words is shown in figures 8-1 and 8-2. These signals are 
available at a processor connector and are used by Varian 
70 series options to detect certain instruction classes. 
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JEUUOY B40}G [O4ZUOD 4aporeg “[-g aunsty 


9F6T- TILA 


DECODER 
B 


DECODER 
A. 


BIS |Bl4 |Bl3 |Bl2 | Bll | BIO | B9 B8 - BO 


ADDRESS CONTRIBUTION 

EXTERNAL SIGNAL FROM 1/0 

ENABLES LEAST SIGNIFICANT 4 BITS OF DECODER A 
WHEN B15 OR B12 ARE ENABLED 

EXTERNAL SIGNAL 

———-— ENABLES DECODER A LEAST SIGNIFICANT 9 BITS 


DECODED FROM 
INSTRUCTION BUFFER 
BITS 12-15 


| 

| 

| 

| | ENABLES INSTRUCTION BUFFER BITS 00-G3 TO 

CONTRIBUTE TO ADDRESS BITS 0-3 

| ——----—-—____-_______ FNABLES INSTRUCTION BUFFEK BITS 04-07 TO 
CONTRIBUTE TO ADDRESS BITS 0-3 

Mee 2 ae el ad Se ERLE DECODER A, CONTROL STORE BITS Al4 
ARID AI3 


A&B - AC 


DECODED FROM 
INSTRUCTION BUFFER 
BITS 08-11 


iCIDA?X) 


Als |Al4| A13] Al2] All [alo [ag 
(NOT estan, apron or 
EXTERNAL SIGNAL; FORCE BIT 2 OF DECODED ADDRESS 
IF FIRST DECOUER 00 BIT IS ON 
— EXTERNAL SIGNAL 
EXTERNAL SIGNAL 
EXTERNAL SIGNAL 
WHEN ENABLED BY B15 FALSE, ENABLES INSTRUCTION BUFFER 
BITS 00-08 TO CONTRIBUTE TO ADDRESS BITS 0-3 
--————— WHEN ENGAGED BY B15 FALSE, ENABLES INSTRUCTION BUFFER 
BITS 04-07 TO CONTRIBUTE TO ADDRESS BITS 0-3 


SOIdOL IWNOILIGGY GNY IOULNOD O/! “3YOLS TOULNOD Y3G003d 


CONTROL STORE 
ADDRESS BIT 


ENABLED COMPONENTS ARE LOGICALLY OR ‘ed, 


DECODER CONTROL STORE, I/O CONTROL AND ADDITIONAL TOPICS 


(FROM DECODER B) 


(DECODED FROM BITS 12-15 
OF INSTRUCTION BUFFER) 


A8-A4 
(FROM DECODER A) 


- BIS=0 OR B12=0 B12 = 0 AND B10 = 1, OR 


BI5 = 0 AND B10 = 1 


INSTRUCTION BUFFER 
BITS 00-03 


B13 = 0 OR (BI5 = 0 AND Al3= 1) 


ALL DECODER COMPONENTS ARE INHIBITED UNLESS 


THE SF FIELD EQUALS 00 AND THE GF FIELD EQUALS 
X1XX AND NO ENABLED INTERRUPT REQUESTS ARE 


INSTRUCTION BUFFER 


ACTIVE, 


IN ADDITION, DECODING MAY BE INHIBITED BY THE 


IM FIELD EQUAL TO 11X0. 


BITS 04-07 


B14 = 0 OR (B15 = 0 AND Al4= }) 


% THIS BIT 1S FORCED TO STATE OF INSTRUCTION BUFFER BIT 03 
IF DECODER B BIT 10 IS ON AND DECODER A BIT 9 IS ON, 


VTEI-1937 A 


Figure 8-2. Decoder Address Components 


8.2 1/0 CONTROL STORE 


8.2.1 Microprogram Initiation 


The microinstruction can initiate 1/O activity by signaling 
an !/O request while forming a starting address for the 
independent I/O control store. An l/O request is made by 
setting the SF field equal to 00 and the IM field equal to 
111X. (If the IM field equals 1110, decode addressing is 
inhibited). 


The !/O control-store starting address is specfied by the 
MT, MR and TS fields. 


1/O request 1/0 Control 
SF = 00 Store Starting 
IM = 111X Address 


*AB1 is most significant bit of the AB field 


The microinstruction can wait for completion of |/O activity 
by specifying a wait for |/O done. This is coded by setting 


the SF field equal to 00 and the IM field equal to 0010. 
Execution of this and subsequent microinstruction will be 
inhibited until the 1/O sequence is completed. If the 1/0 is 
busy performing a sequence and an |/O request is issued 
execution of the microinstruction specifying new 1/0 
activity will be inhibited until the 1/O completes its current 
sequence. 


Standard |/O page zero starting addresses for processor- 
initiated I/O are: 


Hexadecimal 


Address Action 
04 Sense, EXC or EXCA 1/0 sequences 
oc Data Input 
1C Data Output 


1/O operations can be initiated by external events such as 
DMA traps. Standard |/O page zero addresses are: 


Hexadecimal 
Address Action 
40 DMA trap out 
50 DMA trap in 
70 High-speed DMA trap out 
80 High-speed DMA trap in 
DC interrupt 
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8.2.2 1/0 Microprogramming 


The I/O control section performs I/O sequences initiated 
from either the V70 series processor microprograms or 
external DMA trap requests or interrupts. 


1/O microprogramming must be undertaken only with a 
full knowledge of the hardware function of the pro- 
cessor's 1/O control section and the WCS's !/O control 
store. This is described in the V70 Series Processor and 
WCS Reference Manuals. 


No simulator program exists to aid in debugging 1/0 
microprograms. 


All special 1/O microprogramming must be considered an 
engineering design more than a programming task. 


1/0 control performs the following functions in accordance 
with the sequence !/O microinstructions stored in the I/O 
control store: 


* Control the source of data applied to the !/O register 
input bus. 


* 1/O register input bus. 
* Control loading on byte shifting of the I/O register. 


* Initiate memory cycle requests to the Varian 73 
memory control section. 


* Initiate 1/0 bus control signals. 


* Wait for completion of external events such as memory 
cycles, new processor microprogrammed requests, 
external control signals, etc. 


* Signal completion of !/0 activity to the processor's 
central control section. 


1/0 control store formats are shown in figure 8-3. 


The 1/0 address counter is automatically incremented at 
completion of each microinstruction unless a ''WAIT" or 
“IDLE'' state is entered. This counter is cleared to zero by 
system reset. 


i/O microinstructions are executed from sequential ad- 
dresses until the end of the sequence whereupon the 1/0 
becomes idle and ready to accept new requests. 


As the address counter is loaded with its starting address, 
the 1/O control buffer is loaded with the contents of 1/0 
control store location corresponding to the last contents 
of the address register. Following a system reset this will be 
the contents of |/O control store address zero, At all other 
times it will be the ending address of the previous I/O 
sequence. In either case, the standard data will cause bits 
{DLE and DN to become true. 
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IDLE true indicates the |/O control is not idle and further 
requests are to be ignored as long as !DLE is true, the 1/0 
address counter and |/O control buffer are enabled. 


At each succeeding microinstruction time the address 
counter is incremented and_ the I/O control buffer is 
loaded with the contents of the address designated by the 
address counter. The 16 bits of the [/O control buffer 
control all 1/O functions. Their use is described below: 


CDO Control the processor's 
CD1_ I/O data loop multiplexor (IOMXX + ) 


10 I/O Register Input 


O ALU 

1 Memory 1/0 register 
0 1/0 bus byte swapped 
1 1/0 bus 


COD2 = Control the processor's 
CD3 =I/O register 


CD 

32 

00 No action 

01 Shift right (left byte to right byte) 
10 Shift left (right byte to left byte) 
11 Load from ALU 


These bits do not directly control the 1/O register. The 1/0 
register may also be controlled by IDLE (when the I/O is 
idle, the register is continously loaded from the ALU). 


CD4 Enables the processor's |/O register onto 
the E-bus. 
FRY Initiates an 1/O function ready (FRYX-1) 


signal. RYX-| is terminated 247.5 nano- 
seconds later by signal IIIT-. 


Spare Not used. 


DRY Initiates an 1/O bus data ready (DRYX-1) 
signal. DRYX-I is terminated 247,5 nano- 
seconds later by signal IEDRYN+ derived 
from IIT-. 


IDLE Determines idle/busy status of 1/O control. 
While busy the 1/0 can accept no new re- 
quests. 


c‘3 


JEWUOY UONINIYSUIOITI O/| ‘E-Q aan3I4 


LIBU-TILA 


12 1] 
[| fe fon ft ef er 


1.O REGISTER INPUT 


ALU OUTPUT 

MEMORY | O REGISTER 
1O BUS BYTF 5. APPED 
1 O BUS 


1-O REG!. 1FR OPERATION 


NO ACTION 

LEFT BYTE TO RIGHT BYTE 
RIGHT BYTE TO LEFT BYTE 
LOAD FROM SELECTED SOURCE 


ENABLES | O REGISTER TO | O BUS 


IF HIGH SPEED DMA INITIATE | O CONTROL SIGNAL 
FRYF-I 


NOT HIGH SPEED DMA INITIATE | O CONTROL 
SIGNAL FRYX-1 


aes 
Sse ae eee 


IF O SIGNALS | O COMPLETION TO 
CENTRAL CONTROL 


RESERVED FOF FUTUR: OPTION 
REQUEST MEMORY CYCiE 
PUT! CIN (AIT: STATE 


SEU 1 -OrBUSyY 


INITIATE 1. O CONTROL SIGNAL DRY X-1 IF MO HIGH SPEED 
DMA AND INTERRUPT SEQUENCE FLIP-FLOP NOT 3cT ‘HINTF: 


INITIATE | O CONTROL SIGNAL DRYF-1 IF HIGH SPEED DMA 


INITIATE |: O CONTROL SIGNAL IUJX-1 IF NO HIGH SPEED 
DMA AND INTERRUPT SEQUENCE FLIP-FLOP SET (HINTF) 


SELECT WAIT ON EXTERNAL 

LOAD NEW SEQUE NCE ADDRESS WHEN Ne-¥ 
PROCESSOR RESULT RECEIVED 

ADVANCE CLOCK COUNTERS RESET INTERRUPT 
ACKNOWLEDGE 

WAIT FOR MEMORY CYCLE ACKNO‘/LEDGE 
WAIT FOR PROCESSOR REQUEST 

STEER DRY TO t’O BUS 

ACKNOWLEDGE PROCESSOR REQUEST V/HEN 
MEMORY ACKNOWLEDGE RECEIVED 

SPARE 
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ADDRESS ADDRESS FROM CONTROL 
GENERATOR MICROINSTRUCTION 


I/O ADDRESS COUNTER 


1/0 CONTROL STORE 


I/O CONTROL BUFFER 
TRAP AND 
INTERRUPT 
REQUESTS 


MEMORY REQUESTS 


CONTROL SIGNALS TO 

[/O REGISTER 
LO BUS DRIVERS 
lO DONE LO REGISTER INPUT BUS 


1,O IDLE 


I/O BUS CONTROL INTERFACE 


1 O BUS CONTROL SIGNALS 


VTIN-1934 


Figure 8-4. |1/O Control Simplified Block Diagram 
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WAIT Places the !/O control in a "wait" 


RQM 


CRY 


DN 


F2 


See eH OO 


ororo 


State by inhibiting address counter and 
ROM buffer clocks until receipt of a 
designated signal. The 1/O may wait for 
any of the following: 


° new processor request 

. processor interrupt flag reset 
. data memory cycle complete 
. external wait signal 


Selection of the specific condition is 
determined by the function bits EF2, 
EF1 and EFO of the 1/0 control buffer. 


Requests a DMA memory cycle from the 
processor's memory control. 


Channel request. Reserved for 
future option. 


Results in an 1/O done signal (IDNC- 
low) to signal the processor of completion 
of the {/O sequence. 


Function bits which control: 


. selection of ‘wait'’ condition 

. advance of interrupt clock counters 
. steering of DRY 

. acknowledge interrupt requests 

. loading of new sequence addresses 


Select wait on external signal |EXW + 
Load new sequence address from CPU if 
CRQIO + 

Advance !UCX and IUCF clock counters 
Select wait for memory cycle complete 
Select wait on CPU request 

Steer DRY to DRYX-| 

Acknowledge interrupt sequence request 
from CPU 

Not used 


Any |/O sequence continues through successive ROM 
addresses until address counter and ROM buffer clocks 
are inhibited by either of two conditions: 

IDLE becomes false signifying end of sequence or 

WAIT becomes true signaling that the current sequence 

must stop to wait for some external event such as: 


* memory cycle 

* new processor request 
* new processor request 
¢ interrupt flag set 

* external wait line active 


For programmed 1/0 sequences signal DN will become 
active and at the next microinstruction time IDLE will 
become active also. IDLE causes 1/0 sequencing to stop. 


The 1/0 sequence is thus completed leaving the address 
counter loaded with an address whose contents IDLE and 
DN. This will be the first data loaded into the ROM buffer 
when clocks are reenabled. 


8.2.3 Example of 1/0 Microprogram: 
Clear and Input to A 


The flowchart and code sheet following describe the 
standard programmed !/O sequence for V73 input data 
transfers. The corresponding flowchart for the processor 
microprogram to initiate the |/O transfer may be found in 
the second volume of the System Maintenance Manual. 


Referring to the processor microprogram flowchart for the 
sequence required to start the 1/O operation, the first 


central control address is 1A0. This was obtained with 
decode addressing. The entire sequence will now be 
traced. 


1ABM1 (1A0) 


This microinstruction causes the operand register to be 
loaded with a mask word containing only bit 13 true. 
Normal addressing specifies the next address. 


IABM2 (1C3) 


This microinstruction specifies an |/O request with an I/O 
Starting address of OC. If the 1/0 was idle (the 1/0 control 
store buffer IDLE bit was a zero) the I/O control accepts 
the starting address and simultaneously loads its control 
buffer with a standard code of 0088. This places the [/0O in 
its "busy’' state and signals the processor that the 1/0 
operation was accepted. 
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During this microinstruction the processor transfers the 
operand register to register E (this register has been 
designated $1). 


JABM3 (1F3) 


This microinstruction logically OR's the contents of register 
E with the masked (bits 0-8) contents of the instruction 
register. This places the device address, function code and 
bit 13 (specifying an input transfer) at the ALU output. 


In the 1/0 control the 1/O microprogram is executing the 
microinstruction at location OC which loads the 1/0 
register with ALU output data. 


The processor microprogram specifies a “Wait for I/O 
Done'’ which causes further processor operations to be 
suspended until the {/O control signals completion. The 
remainder of the I/O sequence will now be traced. 
Addresses are sequential. 


1/0 address OC is ‘NOP. It performs no function. 


Table 8-1. 1/O Microprogram Example Code 


1/O address of OF continues to enable the I/O register to 
the I/O bus and generates the IFRYX-! control signal to 
signal !/O devices that a new address and function code 
may be sampled. 


1/0 address 10 performs the same function as OF. This 
allows for |/O bus settling time. 


1/0 address 11 selects the !/O bus as an input to the 1/0 
register. The selected |/O device may place its data on the 
1/70 bus. 


1/O address 12 continues to select the |[/O bus as an input 
to the 1/O register and generates control signal IDRYX-I. 


1/O address 13 continues to select the !/O bus as an input 
to the 1/O_ register, continues to generate IDRYX-I and 
causes the |/O register to be loaded with the data placed 
on the I/O bus. 1/0 control buffer bit ''DN'’ becomes false 
permitting microinstruction execution to proceed. 


1/0 address 14 returns the 1/0 control to an idlé condition. 
Simultaneously the next central control microinstruction is 
executed. 


CIA (09D) 


This microinstruction transfers the !/O register contents to 
register O (the A register). The program counter is 
incremented and a new instruction fetch is initiated. The 
microprogram branches to SS3M (02D) where the instruc- 
tion buffer is decoded to branch to the start of the next 
instruction. 
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Note that 1/O address 15 will be executed when the next 
1/0 operation is started. This microinstruction contains 
the standard code of 0088 which will place the I/O in its 
“busy” state. 


8.3 MULTIPLE ENVIRONMENT APPLICATIONS 


This section describes using the V70 series WCS for 
extended instruction execution and dual/multi environ- 
ment applications. 


This section discusses the application of WCS to extend 
the standard V70 series emulation of a 620/f to perform 
additional instructions and functions. It also discussed a 
dual environment implementation, which can be 
extended to multi-environment machine. 


Application of the WCS to Extend Execution 
Capabilities 


Using the macro BCS, it is possible to define entry points in 
extended micro store for a large number of special 
functions. These extended functions can be defined to use 
V70 series hardware not explicit in the 620/f emulation 
such as 16 general purpose accumulator registers and 
more explicit status testing. Examples of application of this 
capability would be implementation of floating point 
arithmetic, stack organizations and so on. Characteristic of 
extended operations is that no primary decodes would 
occur during the operation (exceptions are possible of 
course). It is possible to enable interrupts while disabling 
primary decode so it would be possible to allow interrupts 
during very long microsequences. However, the point of 
interruptability and its ramifications would have to be 
carefully considered. 


Application of the WCS to Dual/Multi 


Environment Operation 


Emulation of instruction architectures other than that of 
the host machine is achieved by performing primary control 
store address decoding in the WCS extended contro! store. 
It is possible to have unique architecture in each 512 word 
block of control store. Some possible examples of this 
would be: 


1. Hardware emulation of a VXX machine under control of 
WCS in the V70 series systems. 


2. Implementation of a higher level Janguage processor 
operating under control in the V70 series systems. 
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CRQIOA Be 0011 |00]- PROGRAM ENTER 
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IFRY 
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JDRY 
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IDRY 


CLK IOR 
EBxx —» IORxx 


VTII-1812 
Figure 8-5. Flowchart of 1/0 Microprogramming Example 
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FROM 
PREVIOUS 
INSTRUCTION 


1A0 


TABM1 


MEM START 
IOR *DCP 
RESET CIt TF 


MASK -* DOR 


MEM START 
INCR P 
A OR IOR—-A 


1/O START 
DOR —S] 


TABM3 
FIELD SELECT 6-8 
WAIT FOR IDN 

S1 OR MASK | --IOR 


MEM START 
INCR P 
B OR JOR +8 


GED 


B OR IOR -DOR 


MEM START 
INCR P 
IOR—A 


MEM START 
INCR P 
IOR-~B 


MEM START 
INCR P 
IOR—+A, DOR 


KAEMA START 
INC P 
DOR — AEN 


ASEAA START 
ItaCR P 
A CR DOR—-A, DOR 


ENABLE D-RCIA & ENTRPT; 
MATI-C21; DOR =B; 
TEST & VESET CINTF 


NEXT 
INSTRUCTION 


VTE-18I3 


Figure 8-5. Flowchart of 1/0 Microprogramming Example (continued) 
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An Example of a Second Environment 


Architecture and Call Sequence 


For our example, we will define a second environment E2 
(as distinguished from the V70 series system environment 
Fl) which can use general registers of the V70 series 
systems as stack pointers, general purpose accumulators 
and so forth. The question arises as to interruptability of 
this second environment and what registers are available 
to E2. 


A macro sequence to call E2 from the V70 series systems 
could be: 


P BCS (105000) page jump to E2 entrance 
micro 

(P) + 1 xxxxx LOC of first instruction of E2 in 
main memory 


(P) + 2 BCS (105001) page jump to E2 interrupt 
return entrance 


E2 Entrance and Interrupt Micro Code 


The normal entrance micro code saves (P) + 2 at register 
E for reference in case of an interrupt. Also, it can be used 
to return jump to the next V70O series system instruction 
when environment 2 is completed. 


Upon receiving an E1 interrupt while in E2, the microse- 


quence (simplified) is as follows: 


STORE 
RETURN 
PATE 


E2 
IWAIT STATE 
REQ. 1/0 


PAGE JMP 
to V70 series 
interrupt micro 


SAVE REG. processor 


bBwWh 


in V70-V74 and 
620/f environment, 
register 5 is all ones 
and register 3 is all 
zeros. Registers 4, E, 
and F are temporary 
storage 


RESTORE 
REG. 3,5 
l's to 5 
0’s to 3 


(continued) 


The content of E is the return instruction location as 
required by control word OD1. Only registers 3,4,5, E and F 
may be subsequently modified by 620 code and it is only 
necessary to save 3,4,5 as the return path will supply 
restoration of E. 


The interrupt return is implemented via the BCS at the V70 
series interrupt return reference. The interrupt return entry 
code restores registers 3, 4, 5 from A, B, and C respectively 
and stores the location of the interrupt return BCS in E. 
The code then restarts the instruction pipeline at the 
reference stored in E. Note that the 70 series interrupt 
routine is responsible for maintaining A, B, and X registers 
(0,1,2). 


E2 Register File Usage 


We can now see that the second environment has 10 
registers (0-9) available for general purpose use, while E is 
allocated for the interrupt return page jump instruction 
address. Registers A, B, C, D and F are also available for 
intermediate usage between interruptable states. 


Considerations of Saving and Storing Status 


The above example does not define how status is to be 
saved and restored. This should be considered when 
defining the interruptability of the second environment. In 
any event, register and overflow status will be maintained 
by the V70 series environment interrupt routines but the 
equal, less than and greater than status is more difficult. 
This may involve saving the status in the interrupt return 
micro code. 


Further Discussion of Multi-Environment Systems 


The above example of interrupt handling in multi-environ- 
ment machine is presented as an exploration of a 
mechanism which solves the problem given a particular set 
of system restraints (interrupt service routines are in the 
host V70 series environment and do not use other than 
normal 620/f instructions, i.e., instructions only use 
registers 0, 1, 2, 3, 4, 5, E, F). 


Each different set of environments may require different 
mechanisms of interrupt handling. Some will require 
saving registers in main memory, possibly at locations 
relative to the location of the interrupt return page jump. 
An alternate environment might utilize its own |/O drivers, 
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which would involve locking out interrupts and swapping 
out interrupt entrance code and possibly also the interrupt 
processing routines. In this situation the second environ- 
ment might offer system executive control as well as its 
optimized functions. When environment, register save/ 
restore will probably have to be comprehensive and in main 
memory. 


Other Multi-Environment Considerations for 
the V70 Series System Reset 


The system reset function will normally be wired to return 
control to the host module (normally zero). 


Power Fail/Restart 


The system executive is expected to contain the necessary 
job restart information in case of a power fail. Therefore, 
the host environment is not required to save facilities of an 
alternate environment (some of which are unknown to the 
host machine). The E2 environment could be saved if 
desired by using a special instruction such as a 620/f 

extension macro which saves and restores the file. 
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Step Mode 


lf it is desirable to single step computer operation in 
alternate environments, it is necessary to micro code a 
halt loop in that environment. The alternate environment 
has the option of enabling or disabling the step function in 
its micro code. 


Conclusion 


This section described two basic applications for the V70 
series WCS. Its use for extending the instruction set of 
the standard 620 emulator is quile straight forward. Its 
application to produce a dual or multi environment 
machine was also seen to be practical and feasible with 
the system problem of interrupt handling examined in 
some detail. In fact, a second environment which offered 
10 general purpose registers and 5 scratch registers for 
implementing stack/queue pointers, floating point reg- 
isters or whatever, was demonstrated. 


Because of the ability to add new instructions to the 620 
emulation in the V70 and the flexibility of micro coding, the 
example is really only one of many possibilities. The 
mechanism generally will be designed to meet require- 
ments of the system definition. 


SECTION 9 
GLOSSARY 


Entries are brief descriptions of terms appearing in the 
text. These definitions reflect the usage preferred for 
consistency and a minimum of terms. Whenever two words 
have been used previously for the same item a choice was 
made in favor of the most meaningful and unambiguous. 


AA 


AB 


addressing 


AF 


ALU 


ALUC 


ALUO 


ALUS 


ALUZ 


application 
software 


ASCII 


assembler 


BB 


microinstruction field of bits 0 - 3 
to select an ALU source on bus A 
and/or destination 


microinstruction bit 35, which is 
used in field-selection addressing 
and I/O requests 


determination of next instruction 
to be executed 


microinstruction field which contri- 
butes to address generation 


Arithmetic and Logical Unit, the 

logical and storage providing data 
transfer and basic arithmetic and 
logical operations in the processor 


flag for ALU carry, bit 11 of proc- 
essor status word 


flag for ALU output all ones, bit 9 
of processor status word 


flag for ALU sign, bit 10 of proc- 
essor status word 


flag for ALU output all zeros, bit 
2 of processor status word 


program oriented to solving problems 


rather than managing systems 
resources 


American Standard Code for Infor- 
mation Interchange codes for char- 
acter representation 


computer program which translates 
symbolic statements into machine 
executable instructions, see MIDAS 


microinstruction field of bits 4 
through 7, which specify the ALU 
(continued) 


BCS 


BIC 


binary 


BYTA 


byte 


CF 


control 
buffer 


control 
store 


cycle 


cycle, 
memory 


cyclic 
redundancy 
check 


data path 


DCS 


source on the B bus or a part of 
mask literal 


mnemonic for Branch to Control 
Store, a 16-bit MACRO 
instruction which initiates 
execution of microprograms 

in WCS 


Buffer Interlace Controller 


numbering system in which only two 
states are represented, one and zero 


flag which indicates left or right 
byte of word 


8-bit unit 


microinstruction field which varies 
the type of carry action on ALU 
actions 


contains current microinstruction 
being executed; separate for 
central control logic (64 bits) 
and |/O control logic (16-bits) 


memory in which microinstructions 
are stored 


time required to execute one micro- 
instruction 


time required to access and restore 
storage in main memory 


technique for validating storage or 
transmission reliability 


transfer media for data within 
processor 


Decoder Control Store, optional 
programmable contro! store for 
instruction decoding 
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DMA 


direct 
addressing 


DSB 


emulation, 
620 


FF 


field select 


GF 


GPR 


GPRS 


hexadecimal 
or hex 


instruction 
buffer 


instruction 
register 


10CS 


IOR 


key register 
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Direct Memory Access 


instructions contain actual effective 
memory address to be used. in con. 
trast with relative or indirect ad- 
dressing 


shift flag; SHFT 


standard microprogram that 
resides in control store 

page 0. and directs execution 
of 620 instructions 


microinstruction field which specifies 
ALU action 


technique of addressing which uses 
the bits of the instruction re- 
gister to determine a microprogram 
branch address 


microinstruction field. which specifies 
condition to be tested 


general-purpose register. one of 16 
16-bit registers 


general-purpose register 0 
bit 15 (sign) 


numbering system using base 16. re- 
presenting numbers with digits and 
letters A through F 


Instruction Fetch 


interrupt address supplied by option 
board to indicate type of interrupt 


microinstruction field designating 
type of memory control 


storage for instruction immediately 
after fetched from memory 


storage for instruction for an 
instruction to be executed 


1/O Control Store, optional 
unit of programmable storage for 
varying |/O rates and disciplines 


1/O Register 


four-bit register which supplies 
signals for memory operations used 
by memory-map option 


LA 


LB 


MAD 


mask 


memory map 


micrainstruc- 


tron 


microprogram 


MIR 
MIRS 


MK 


MR 


MS 


MT 


MULS 


NORM 


OF 


OP 


OPR 


overflow 


page 


microinstruction field which in 
conjunction with AA specifies the 
ALU input on bus A 
microinstruction field which in 


conjunction with BB specifies the 
ALU input on bus B 


Memory Address Register 


literal constant ANDed with instruc- 
tion register 


hardware option to allow addressing 
memory to 256K 


64-bit word from WCS specifying the 
actions to occur during one cycle 


vehicle for implementing control 
function of a computer 


Memory Input Register 
flag for memory input register sign 


16-bit mask field (assembler 
mnemonic) 


microinstruction bit 37 used to 
specify !/O address bit 6 or to 
control AB field use 


microinstruction addressing field 


bit 50 of microinstruction which 
specifies bit 7 of an 1/O address 


Multiply Sign flag 
Normalize flag 


Operand fetch 


microinstruction fields combined to 
specify ALU action (bits 23 - 17) 


operand register 
ALU action indicated by OVFL flag; 
condition caused by attempt to 


push too many addresses into micro- 
program stack 


program counter 


unit of writable control store of 
512 words, 64 bits each 


page jump 


pop 


processor 


program 
counter 


push 


pipelining 


QuOS 


RF 


ROM 


SF 


SH 


SHFT 


SHTC 


a branch with a microprogram beyond 


the extent of the page currently being 
executed 


to remove an address from top 
of microprogram stack 


unit that performs and controls 
execution of instruction 


register for memory address; 
usually used for keeping track 
of MACRO level execution 


to add an address to top 
of stack 


technique which allows next instruc- 
tion to be fetched during an other- 
wise unused memory cycle 


flag for quotient 


microinstruction field of bits 24 
through 26 used to specify transfer 
and increment of some special 
registers 


Read Only Memory: such as page 
of V70 series control stores; 
contains the microinstructions 

to emulate Varian 620 system 


bit 15 of microinstruction; specifies 
shift of operand register or is part 
of mask literal 


bits 42 and 43 of microinstruction: 
specify interpretation of the IM 
field 


microinstruction field which 
specifies some special ALU 
actions or shift operations 


flag for shift 


flag for overflow of the shift 
‘counter . 
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stack, linked storage locations (16) used 
microprogram in microprogram subroutine call and 
return 
STAT processor status word 
STEP mode of computer execution one 


instruction at a time 
SSW SENSE switch 1 - 3 on control panel 


SUPR supervisor mode flag, bit 1 of 
processor status word 


TF microinstruction field of bits 45 
and 46 which specify whether 
testing occurs and whether it is 
for true or false condition 


TS microinstruction field of bits 60 
through 63, which selects a field 
from the instruction register, 
specifies a page number for a 
page jump, contributes a portion 
of an 1/O address, or enables 
selected interrupts 


underflow condition upon attempting to remove 
or pop more addresses than are in 


a microprogram stack 


VF microinstruction bit 14, which 
specifies moving bit 15 of RO to 
divide-sign bit (DSB), or a part 
of mask 


WCS Writabie Control Store; which is read 
and loaded over the |/O bus 


WR microinstruction field of bit 
16 that specifies whether or 
not the general-purpose registers 
are being loaded 


WF single bit (13) in microinstruction 
to designate transfer of the ALU 
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